【java 分页工具类】分页工具PageBean(149)

分页工具类:

java 复制代码
package com.itheima3;

import java.util.ArrayList;
import java.util.List;

public class PageBean<T> {
    private int pageSize; // 每页记录数
    private int pageNo; // 当前页
    private int totalPages; // 总页数
    private int totalRecords; // 总记录数
    private List<T> list;

    public int getPageSize() {
        return pageSize;
    }

    // 设置每页记录数
    public void setPageSize(int pageSize) {
        if (pageSize > 0) {
            this.pageSize = pageSize;
        } else {
            this.pageSize = 10;
        }
    }

    public int getPageNo() {
        return pageNo;
    }

    // 设置当前页
    public void setPageNo(int pageNo) {
        if (pageNo <= 1) {
            this.pageNo = 1;
        } else if (pageNo > this.totalPages) {
            this.pageNo = this.totalPages;
        } else {
            this.pageNo = pageNo;
        }
    }

    public int getTotalPages() {
        return totalPages;
    }

    // 设置总页数
    public void setTotalPages() {
        this.totalPages = this.totalRecords % this.pageSize == 0 ? this.totalRecords / this.pageSize
                : this.totalRecords / this.pageSize + 1;
    }

    public int getTotalRecords() {
        return totalRecords;
    }

    // 设置总记录数
    public void setTotalRecords(int totalRecords) {
        if (totalRecords >= 0) {
            this.totalRecords = totalRecords;
        } else {
            this.totalRecords = 0;
        }
    }

    public List<T> getList() {
        return list;
    }

    public void setList(List<T> list) {
        this.list = list;
    }

    // 当前页记录列表
    public void queryPager(int pageNo, int pageSize, List<T> list) {
        // 设置总记录数
        if (list != null && list.size() != 0) {
            this.setTotalRecords(list.size());
        } else {
            this.setTotalRecords(0);
        }
        // 设置每页记录数
        this.setPageSize(pageSize);
        // 设置总页数
        this.setTotalPages();
        // 设置当前页
        this.setPageNo(pageNo);
        // 设置当前页记录数
        if (list != null && list.size() != 0) {
            if (pageNo == this.totalPages) {
                this.list = list.subList((pageNo - 1) * pageSize, this.totalRecords);
            } else {
                this.list = list.subList((pageNo - 1) * pageSize, pageNo * pageSize);
            }
        } else {
            this.list = new ArrayList<>();
        }

    }

    public boolean isPrePage() {
        if (this.pageNo > 1) {
            return true;
        }
        return false;
    }

    public boolean isNextPage() {
        if (this.pageNo < this.totalPages) {
            return true;
        }
        return false;
    }

    public int getPrePageNo() {
        if (isPrePage()) {
            return this.pageNo - 1;
        }
        return this.pageNo;
    }

    public int getNextPageNo() {
        if (isNextPage()) {
            return this.pageNo + 1;
        }
        return this.pageNo;
    }
    
}

控制层:

java 复制代码
public PageBean queryList(@RequestParam(value = "page", defaultValue = "1") Integer page,
		@RequestParam(value = "pageSize", defaultValue = "20") Integer pageSize) {
	//	if(page == null){
	//		page = 1;
	//	}
	//	if(pageSize == null){
	//		pageSize = 10;
	//	}
		List<User> list = userService.queryList();  // 数据库查询返回的List;
		if (CollectionUtils.isNotEmpty(list)) {
			PageBean<User> bean = new PageBean<>();
			bean.queryPager(page, pageSize, list);
			return bean;
		}
		return null;
	}
	
相关推荐
q***d17327 分钟前
Rust在网络中的协议栈
开发语言·网络·rust
星释28 分钟前
Rust 练习册 88:OCR Numbers与光学字符识别
开发语言·后端·rust
一生要强的ymy29 分钟前
Polar PHP是世界上最好的语言(困难)
开发语言·php
我命由我123451 小时前
Java NIO 编程 - NIO Echo Server、NIO Client(NIO 异步客户端、NIO Selector 异步客户端)
java·开发语言·网络·java-ee·intellij-idea·intellij idea·nio
嗯、.1 小时前
使用Itext9生成PDF水印,兼容不同生成引擎的坐标系(如: Skia、OpenPDF)
java·pdf·itextpdf·openpdf·坐标变换矩阵
前端炒粉2 小时前
35.LRU 缓存
开发语言·javascript·数据结构·算法·缓存·js
星释3 小时前
Rust 练习册 75:ETL与数据转换
开发语言·rust·etl
happyjoey2173 小时前
使用Qt自带的Maintenance Tool将Qt6.9升级为QT6.10
开发语言·qt
断剑zou天涯4 小时前
【算法笔记】窗口内最大值或最小值的更新结构
java·笔记·算法
m***66735 小时前
SQL 实战—递归 SQL:层级结构查询与处理树形数据
java·数据库·sql