springboot项目中的返回值是public static <T> JsonData ok(List<T> data) { if (data instanceof Page) { Map<String, Object> map = new HashMap<>(); List<T> list = new ArrayList<>(); for (T object : data) { list.add(object); } map.put("list", list); PageInfo info = new PageInfo(data); map.put("total", info.getTotal()); map.put("pages", info.getPages()); map.put("size", info.getSize()); map.put("pageSize", info.getPageSize()); map.put("pageNum", info.getPageNum()); return new JsonData(CODE_SUCCESS, msgSuccess, map); } else { return new JsonData(CODE_SUCCESS, msgSuccess, data); } },请问这个分页查询的util类该如何修改?
时间: 2024-02-14 17:13:21 浏览: 20
您好,根据您提供的返回值函数,这个分页查询的util类应该是使用了MyBatis-PageHelper插件进行分页的,返回的数据类型为Page<T>。
在这个util类中,可以使用以下代码进行分页查询:
```java
public class PageUtils {
public static <T> PageInfo<T> startPage(int pageNum, int pageSize, Supplier<List<T>> supplier) {
PageHelper.startPage(pageNum, pageSize);
List<T> list = supplier.get();
return new PageInfo<T>(list);
}
}
```
其中,pageNum和pageSize分别为当前页码和每页条数,supplier为查询数据的逻辑,返回一个List<T>类型的查询结果。使用PageInfo对查询结果进行包装,返回给前端。这里使用了Java 8中的Supplier函数式接口,可以灵活地传入查询数据的逻辑。
使用方法如下:
```java
PageInfo<User> pageInfo = PageUtils.startPage(pageNum, pageSize, () -> userDao.getUserList());
List<User> userList = pageInfo.getList();
```
其中,`() -> userDao.getUserList()`是一个Lambda表达式,用于传入查询数据的逻辑。这里假设有一个`UserDao`接口,其中有一个`getUserList()`方法,返回一个`List<User>`类型的查询结果。
使用以上代码进行分页查询,即可在返回值中包含分页信息,方便前端进行分页展示。