这篇文章给大家介绍使用Java怎么实现一个分页工具类,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
package com.bw.utils;
/**
* 分页工具类
*
* @author H.ros
*
*/
public class PageUtils2 {
// 当前页(从页面获取的当前页码,未计算)
private int currentPage;
// 前一页
private int prevPage;
// 下一页
private int nextPage;
// 尾页
private int lastPage;
// 总记录数
private int count;
// 每页的条数
private int pageSize = 3;
// 分页计入数(使用时调用的初始页,计算后)
private int pageRecord;
// 页面分页模型(传入页面使用的DOM)
private String page;
// 有参构造器
public PageUtils2(String currentPage, int count, int pageSize) {
init(currentPage, count, pageSize);
initLastPage();
initCurrentPage();
initPrevPage();
initNextPage();
initPageRecord();
initPage();
}
// 初始化三个重要元素
private void init(String currentPage, int count, int pageSize) {
if (currentPage == null || currentPage == "" || currentPage == "0") {
currentPage = "1";
}
this.currentPage = Integer.parseInt(currentPage);
this.count = count;
this.pageSize = pageSize;
}
// 初始化尾页
private void initLastPage() {
if (count % pageSize == 0) {
lastPage = count / pageSize;
} else {
lastPage = count / pageSize + 1;
}
}
// 初始化并矫正当前页(防止外部访问出错)
private void initCurrentPage() {
if (currentPage < 1) {
currentPage = 1;
} else if (currentPage > lastPage) {
currentPage = lastPage;
}
}
// 初始化上一页
private void initPrevPage() {
if (currentPage != 1) {
prevPage = currentPage - 1;
}else{
prevPage = 1;
}
}
// 初始化下一页
private void initNextPage() {
if (currentPage != lastPage) {
nextPage = currentPage + 1;
}else{
nextPage = lastPage;
}
}
// 初始化分页计入数
private void initPageRecord() {
pageRecord = (currentPage - 1) * pageSize;
if(pageRecord < 0){
pageRecord = 0;
}
}
// 初始化页面分页模型(按键中的class属性是bootstrap的样式)
private void initPage() {
page = "第" + currentPage + "/" + lastPage + "页,共" + count + "条记录。";
page += "<input type='button' value='首页' οnclick='page(1)' class='btn btn-sm'/>";
page += "<input type='button' value='上一页' οnclick='page(" + prevPage + ")' class='btn btn-sm'/>";
page += "<input type='button' value='下一页' οnclick='page(" + nextPage + ")' class='btn btn-sm'/>";
page += "<input type='button' value='尾页' οnclick='page(" + lastPage + ")' class='btn btn-sm'/>";
}
/*
* 对外访问通道
*/
public int getCurrentPage() {
return currentPage;
}
public int getPrevPage() {
return prevPage;
}
public int getNextPage() {
return nextPage;
}
public int getLastPage() {
return lastPage;
}
public int getCount() {
return count;
}
public int getPageSize() {
return pageSize;
}
public int getPageRecord() {
return pageRecord;
}
public String getPage() {
return page;
}
}
使用方法:
里面很多的地方都会计算好,使用时只用传入三个参数:
//currentPage是从前台传来的当前页码,count是数据的总统计数,pageSize是每页显示的条数,
//count必须是数据中的查询结果哦。这样才能与前台保持页码一致。
PageUtils util = new PageUtils(currentPage, count, pageSize);
然后直接将它的一个Page属性传入前台页面就行:
mv.addObject("page", util.getPage());
在前台页面直接用EL表达式接收解析:
${page}
在js中要设置一个函数:
function page(){}
//因为工具类中添加的是onclick的js点击事件,我们必须使用js的一个函数来进行后台处理;
//如果不想使用,在工具类中删除即可。
关于使用Java怎么实现一个分页工具类就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。