分页一般分为三步:
- 前端传入查询条件(pagesize,currentPage,id)等
- 调用Dao方法,数据库查询
- 将查寻结果的数据封装到PageBean中集合,返回前端显示
常见的问题有:
- 初次访问,currentPage=null,所以执行第二步操作时必须要将赋值currentPage=1,否则会抛出异常NullPointException
- 第三步,前台展示数据时,若currentPage大于totalPage时,要控制显示效果,给予好的用户体验。
解决方法再后面贴出,请往下看
分页的JavaBean:
package cn.edu.hgu.model;
import java.util.List;
public class PageBean<Book> {
//当前页
private Integer currentPage;
//每页显示多少条
private Integer pageSize=5;
//一共有多少条数据
private Integer totalCount;
//一共有多少页
private Integer totalPage;
//用来装每页的数据
private List<Book> pageData;
//调用构造方法,当页面初始化时currentpage=1
public PageBean(Integer currentPage) {
super();
if(currentPage==null){
this.currentPage=1;
}else{
this.currentPage = currentPage;
}
}
public Integer getCurrentPage() {
return currentPage;
}
public void setCurrentPage(Integer currentPage) {
this.currentPage = currentPage;
}
public Integer getPageSize() {
return pageSize;
}
public void setPageSize(Integer pageSize) {
this.pageSize = pageSize;
}
public Integer getTotalCount() {
return totalCount;
}
public void setTotalCount(Integer totalCount) {
this.totalCount = totalCount;
}
public Integer getTotalPage() {
if (totalCount % pageSize == 0) {
totalPage = totalCount / pageSize;
} else {
totalPage = totalCount / pageSize + 1;
}
return totalPage;
}
public void setTotalPage(Integer totalPage) {
this.totalPage = totalPage;
}
public List<Book> getPageData() {
return pageData;
}
public void setPageData(List<Book> pageData) {
this.pageData = pageData;
}
}
问题一解决方案:
//此处传currentPage
pageBean1 = new PageBean<>(this.currentPage);
pageBean1.setPageData(indexService.findBookById(pageBean1.getCurrentPage(), pageBean1.getPageSize(),model.getId()));
通过创建Page Bean对象的构造函数,处理current Page=null的情况
问题二解决方案:
利用Jstl标签库提供的 < c:choose>标签,详细用法参照:
<c:choose>
<c:when test="${pageBean1.currentPage>=pageBean1.totalPage}">
//若当前页大于总页数,显示这个
第${pageBean1.totalPage}页/共${pageBean1.totalPage}页
</c:when>
<c:otherwise>
//否则显示这个
第${pageBean1.currentPage}页/共${pageBean1.totalPage}页
</c:otherwise>
</c:choose>