借助PageHelper的PageInfo,实现手动分页

需求:再mysql 查询出数据后,根据数据对List进行进一步处理,现在需要再对List进行分页,所以需要进行手动分页

当list的集合来自多个数据源的时候,所使用的PageHelper就不适合分页查询了,必须要手动分页。
以下是封装的工具类

import com.github.pagehelper.PageInfo;
import java.util.List;

public class PageInfoTool {
    public static <T> PageInfo<T> initPageInfoObj(int currentPage, int total, int pageSize, PageInfo<T> pageInfo, List<T> list) {
        pageInfo.setNextPage(currentPage < ((total + pageSize - 1) / pageSize) ? currentPage + 1 : currentPage);
        pageInfo.setTotal(total);
        pageInfo.setPageSize(pageSize);
        pageInfo.setPageNum(currentPage);
        pageInfo.setPages((total + pageSize - 1) / pageSize);
        pageInfo.setPrePage(currentPage > 1 ? currentPage - 1 : currentPage);
        pageInfo.setIsFirstPage(currentPage == 1 ? true : false);
        pageInfo.setIsLastPage(currentPage == (total + pageSize - 1) / pageSize ? true : false);
        pageInfo.setHasPreviousPage(currentPage == 1 ? false : true);
        pageInfo.setHasNextPage(currentPage == (total + pageSize - 1) / pageSize ? false : true);
        pageInfo.setNavigatePages((total + pageSize - 1) / pageSize);
        int start = 0;
        int end = 0;
        if(pageInfo.getPageNum() == 1){
            start = 0;
            pageInfo.setStartRow(0);
            pageInfo.setHasPreviousPage(false);
            pageInfo.setPrePage(0);
            pageInfo.setIsFirstPage(true);
        }else{
            start = pageInfo.getPageSize()*(pageInfo.getPageNum()-1);
            pageInfo.setStartRow(pageInfo.getPageSize()*(pageInfo.getPageNum()-1));
            pageInfo.setHasPreviousPage(true);
            pageInfo.setPrePage(pageInfo.getPageNum()-1);
            pageInfo.setIsFirstPage(false);
        }
        if((pageInfo.getStartRow()+pageInfo.getPageSize() > pageInfo.getTotal())){
            end = (int) pageInfo.getTotal();
            pageInfo.setEndRow((int) pageInfo.getTotal());
            pageInfo.setHasNextPage(false);
            pageInfo.setIsLastPage(true);
        }else {
            end  = start + pageInfo.getPageSize();
            pageInfo.setEndRow(pageInfo.getStartRow() + pageInfo.getPageSize());
            pageInfo.setHasNextPage(true);
            pageInfo.setNextPage(pageInfo.getPageNum() + 1);
            pageInfo.setIsLastPage(false);
            pageInfo.setEndRow((pageInfo.getPageNum())*pageSize);
        }
        return calcNavigatepageNums(pageInfo,start,end,list);
    }

    private static <T> PageInfo<T> calcNavigatepageNums(PageInfo<T> pageInfo,int start,int end,List<T> list) {
        //当总页数小于或等于导航页码数时
        if (pageInfo.getPages() <= pageInfo.getNavigatePages()) {
            pageInfo.setNavigatepageNums(new int[pageInfo.getPages()]);
            for (int i = 0; i < pageInfo.getPages(); i++) {
                pageInfo.getNavigatepageNums()[i] = i + 1;
            }
        } else { //当总页数大于导航页码数时
            pageInfo.setNavigatepageNums(new int[pageInfo.getNavigatePages()]);
            int startNum = pageInfo.getPageNum() - pageInfo.getNavigatePages() / 2;
            int endNum = pageInfo.getPageNum() + pageInfo.getNavigatePages() / 2;

            if (startNum < 1) {
                startNum = 1;
                //(最前navigatePages页
                for (int i = 0; i < pageInfo.getNavigatePages(); i++) {
                    pageInfo.getNavigatepageNums()[i] = startNum++;
                }
            } else if (endNum > pageInfo.getPages()) {
                endNum = pageInfo.getPages();
                //最后navigatePages页
                for (int i = pageInfo.getNavigatePages() - 1; i >= 0; i--) {
                    pageInfo.getNavigatepageNums()[i] = endNum--;
                }
            } else {
                //所有中间页
                for (int i = 0; i < pageInfo.getNavigatePages(); i++) {
                    pageInfo.getNavigatepageNums()[i] = startNum++;
                }
            }
        }
        if (start < end && end <= pageInfo.getTotal()){
            pageInfo.setList(list.subList(start,end));
        }
        if(pageInfo.getSize() == 0) {
            pageInfo.setStartRow(0);
            pageInfo.setEndRow(0);
        } else {
            pageInfo.setStartRow(pageInfo.getStartRow() + 1);
            pageInfo.setEndRow(pageInfo.getStartRow()-1+pageInfo.getPageSize());
        }
        return pageInfo;
    }

}

需要手动分页时,代码中不要使用以下方法:

PageHelper.startPage(params.getPageNum(),params.getPageSize());

然后将list丢入pageInfo最后执行PageInfoTool中的initPageInfoObj方法

PageInfo<T> pageInfo = new PageInfo<>(sumDataList);
pageInfo = PageInfoTool.initPageInfoObj(params.getPage(),list.size(),params.getPageSize(),pageInfo,list);

这样就实现了手动分页,我的工具类返回的PageResult是经过了封装的,可以根据你们的需求去改造

PageHelper是一个优秀的分页插件,可以快速实现分页功能。而PageInfoPageHelper中用于封装分页信息的类,可以方便地获取分页相关的信息,比如当前页码、总页数、总记录数等。下面是一个基于PageHelperPageInfo实现分页的示例代码: 1. 首先,在pom.xml中添加PageHelper依赖: ```xml <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>5.2.1</version> </dependency> ``` 2. 在需要进行分页的Mapper方法中添加分页参数: ```java public interface UserMapper { List<User> selectAllUsers(); List<User> selectUsersByPage(@Param("start") int start, @Param("pageSize") int pageSize); } ``` 3. 在DAO层中进行分页操作: ```java @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public PageInfo<User> getUsersByPage(int pageNum, int pageSize) { PageHelper.startPage(pageNum, pageSize); List<User> userList = userMapper.selectAllUsers(); return new PageInfo<>(userList); } } ``` 4. 在Controller中获取分页数据: ```java @RestController @RequestMapping("/users") public class UserController { @Autowired private UserService userService; @GetMapping public PageInfo<User> getUsersByPage(@RequestParam(defaultValue = "1") int pageNum, @RequestParam(defaultValue = "10") int pageSize) { return userService.getUsersByPage(pageNum, pageSize); } } ``` 5. 在前端页面中使用PageInfo组件进行分页: ```html <ul> <li v-for="user in userList" :key="user.id">{{ user.name }}</li> </ul> <PageInfo :page-info="pageInfo" @page-change="handlePageChange" /> ``` ```js import PageInfo from 'vue-pageinfo' export default { components: { PageInfo }, data() { return { userList: [], // 当前页的用户列表 pageInfo: null // 分页信息 } }, mounted() { this.getUserList() }, methods: { getUserList() { axios.get('/users', { params: { pageNum: this.pageInfo ? this.pageInfo.pageNum : 1, pageSize: this.pageInfo ? this.pageInfo.pageSize : 10 } }).then(response => { this.userList = response.data.list this.pageInfo = response.data }) }, handlePageChange(page) { // 处理页码改变事件 this.pageInfo.pageNum = page this.getUserList() } } } ``` 希望这个示例能够帮助到您!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CodingPeppa

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值