若依框架封装的 startPage() 方法只对该语句以后的第一个查询(Select)语句得到的数据进行分页。
而现在的需求是要对查询到以后进行拼接或筛选的list数据进行分页操作并在前端展示。
在git上有关于这个的提问
若依大佬简单说了解决办法,在此进行详细的补充
从startPage()点进去
这里的pageNum和pageSize是从前端数据里传进来的分页对象的属性
然后对数据进行处理,当固定每页10条数据时:
public TableDataInfo list(SysLogininfor logininfor){
PageDomain pageDomain = TableSupport.buildPageRequest();
Integer pageNum = pageDomain.getPageNum();
Integer pageSize = pageDomain.getPageSize();
//过滤数据
List<SysLogininfor> list = logininforService.selectLogininforList(logininfor);
List<SysLogininfor> list1 = new ArrayList<>();
for (SysLogininfor sysLogininfor : list) {
if(sysLogininfor.getLoginName().equals(sysUser.getLoginName())){
list1.add(sysLogininfor);
}
}
//获取处理好的list集合
int num = list1.size();
list1 = list1.stream().skip((pageNum - 1) * pageSize).limit(pageSize).collect(Collectors.toList());
TableDataInfo rspData = new TableDataInfo();
rspData.setCode(0);
rspData.setRows(list1);
rspData.setTotal(num);
return rspData;
}