一、分页的思路

首先我们得知道写分页代码时的思路,保持思路清晰,有步骤的进行,才能行云如水。
先来看看分页的效果

这便是一个分页导航,个中能得到的数据有

jsp分页功能深刻进修JavaWeb十一分页功效的实现 jQuery

totalRecord:统共员工数,数据库中总的记录数,这里有55条

totalPage:总页数,11页

pageSize:每页显示的记录数,这里可以看到每页显示5条

pageNum:当前页为第几页,比如图中就为第9页,由于9是没有超链接的,

start:统共能显示5页,让用户进行点击,7为起始页

end:11为能显示的尾页,也便是,如果用户点击第8页,那么start就为6,end就为10,每次都只有5页共点击查询。

每次能够得到对应页数所须要的5条数据,等等这些数据都要在jsp中显示出来,也便是说,每次都要从后台拿那么多数据过来进行显示,以是我们就想办法把这些数据封装在一个javabean当中,每次后台都将查询到的数据放入javabean工具中,我们只须要将该工具存入request浸染域,然后在jsp页面中从域中获取须要的数据即可。

二、创建PageBean存放数据

PageBean.java

统共须要8个属性pageNum、pageSize、totalRecord、totalPage、startIndex、list、start、end,

pageNum、pageSize、totalRecord:通过布局方法就能得到。
pageNum要求页面提交过来的参数,pageSize是自己设置的,totalRecord是查询数据库得到的

totalPage、startIndex、start、end是通过内部算法得出,

list须要通过查询数据库在通过set办法得到。

把稳:该类利用泛型是为了不仅仅在这个项目中利用,在别的项目中也同样可以利用,

代码如下

1 package com.jxpx.myums.domain; 2 3 import java.util.List; 4 5 public class PageBean<T> { 6 //已知数据 7 private int pageNum; //当前页,从要求那边传过来。
8 private int pageSize; //每页显示的数据条数。
9 private int totalRecord; //总的记录条数。
查询数据库得到的数据 10 11 //须要打算得来 12 private int totalPage; //总页数,通过totalRecord和pageSize打算可以得来 13 //开始索引,也便是我们在数据库中要从第几行数据开始拿,有了startIndex和pageSize, 14 //就知道了limit语句的两个数据,就能得到每页须要显示的数据了 15 private int startIndex; 16 17 18 //将每页要显示的数据放在list凑集中 19 private List<T> list; 20 21 //分页显示的页数,比如在页面上显示1,2,3,4,5页,start就为1,end就为5,这个也是算过来的 22 private int start; 23 private int end; 24 25 //通过pageNum,pageSize,totalRecord打算得来tatalPage和startIndex 26 //布局方法中将pageNum,pageSize,totalRecord得到 27 public PageBean(int pageNum,int pageSize,int totalRecord) { 28 this.pageNum = pageNum; 29 this.pageSize = pageSize; 30 this.totalRecord = totalRecord; 31 32 //totalPage 总页数 33 if(totalRecord%pageSize==0){ 34 //解释整除,恰好每页显示pageSize条数据,没有多余一页要显示少于pageSize条数据的 35 this.totalPage = totalRecord / pageSize; 36 }else{ 37 //不整除,就要在加一页,来显示多余的数据。
38 this.totalPage = totalRecord / pageSize +1; 39 } 40 //开始索引 41 this.startIndex = (pageNum-1)pageSize ; 42 //显示5页,这里自己可以设置,想显示几页就自己通过下面算法修正 43 this.start = 1; 44 this.end = 5; 45 //显示页数的算法 46 47 if(totalPage <=5){ 48 //总页数都小于5,那么end就为总页数的值了。
49 this.end = this.totalPage; 50 }else{ 51 //总页数大于5,那么就要根据当前是第几页,来判断start和end为多少了, 52 this.start = pageNum - 2; 53 this.end = pageNum + 2; 54 55 if(start < 0){ 56 //比如当前页是第1页,或者第2页,那么就不如和这个规则, 57 this.start = 1; 58 this.end = 5; 59 } 60 if(end > this.totalPage){ 61 //比如当前页是倒数第2页或者末了一页,也同样不符合上面这个规则 62 this.end = totalPage; 63 this.start = end - 5; 64 } 65 } 66 } 67 //get、set方法。
68 public int getPageNum() { 69 return pageNum; 70 } 71 72 public void setPageNum(int pageNum) { 73 this.pageNum = pageNum; 74 } 75 76 public int getPageSize() { 77 return pageSize; 78 } 79 80 public void setPageSize(int pageSize) { 81 this.pageSize = pageSize; 82 } 83 84 public int getTotalRecord() { 85 return totalRecord; 86 } 87 88 public void setTotalRecord(int totalRecord) { 89 this.totalRecord = totalRecord; 90 } 91 92 public int getTotalPage() { 93 return totalPage; 94 } 95 96 public void setTotalPage(int totalPage) { 97 this.totalPage = totalPage; 98 } 99 100 public int getStartIndex() {101 return startIndex;102 }103 104 public void setStartIndex(int startIndex) {105 this.startIndex = startIndex;106 }107 108 public List<T> getList() {109 return list;110 }111 112 public void setList(List<T> list) {113 this.list = list;114 }115 116 public int getStart() {117 return start;118 }119 120 public void setStart(int start) {121 this.start = start;122 }123 124 public int getEnd() {125 return end;126 }127 128 public void setEnd(int end) {129 this.end = end;130 }131 132 133 }

三、在service层编写业务逻辑代码

实在便是在该层将我们所须要的PageBean工具构建好,返回给上一层

User类是我们须要显示的数据的封装后的javabean。

四、Servlet中编写掌握代码

五、JSP中显示数据,构建分页导航

由于将我们所有须要的数据都封装在了pageBean中,pageBean工具又在request域中,以是在jsp页面中,我们只须要拿到我们所须要的数据,进行显示即可,布局导航图须要把稳的有一点,逻辑要搞清楚,想要显示什么不想显示什么,全屏自己掌握了,只须要记得一点,在要求Servlet时,须要把要求的页码交给做事器。
不然做事器不知道你要得到第几页的数据。

我做的导航图的逻辑代码

显示所有员工数量、总页数

首先超链接

如果当前页为第一页时,就没有上一页这个超链接显示

如果当前页不是第一页也不是末了一页,则有上一页和下一页这个超链接显示

如果当前页是末了一页,则只有上一页这个超链接显示,下一页没有

尾页超链接

代码

1 <%-- 构建分页导航 --%> 2 共有${requestScope.pageBean.totalRecord}个员工,共${requestScope.pageBean.totalPage }页,当前为${requestScope.pageBean.pageNum}页 3 <br/> 4 <a href=\"大众${pageContext.request.contextPath}/FindAllWithPage?pageNum=1\"大众>首页</a> 5 <%--如果当前页为第一页时,就没有上一页这个超链接显示 --%> 6 <c:if test=\"大众${requestScope.pageBean.pageNum ==1}\"大众> 7 <c:forEach begin=\"大众${requestScope.pageBean.start}\"大众 end=\"大众${requestScope.pageBean.end}\"大众 step=\公众1\公众 var=\公众i\公众> 8 <c:if test=\"大众${requestScope.pageBean.pageNum == i}\"大众> 9 ${i}10 </c:if> 11 <c:if test=\公众${requestScope.pageBean.pageNum != i}\"大众>12 <a href=\"大众${pageContext.request.contextPath}/FindAllWithPage?pageNum=${i}\"大众>${i}</a> 13 </c:if> 14 </c:forEach>15 <a href=\"大众${pageContext.request.contextPath}/FindAllWithPage?pageNum=${requestScope.pageBean.pageNum+1}\"大众>下一页</a> 16 </c:if>17 18 <%--如果当前页不是第一页也不是末了一页,则有上一页和下一页这个超链接显示 --%>19 <c:if test=\"大众${requestScope.pageBean.pageNum > 1 && requestScope.pageBean.pageNum < requestScope.pageBean.totalPage}\"大众>20 <a href=\"大众${pageContext.request.contextPath}/FindAllWithPage?pageNum=${requestScope.pageBean.pageNum-1}\公众>上一页</a>21 <c:forEach begin=\"大众${requestScope.pageBean.start}\"大众 end=\"大众${requestScope.pageBean.end}\公众 step=\"大众1\"大众 var=\"大众i\"大众> 22 <c:if test=\公众${requestScope.pageBean.pageNum == i}\"大众>23 ${i}24 </c:if> 25 <c:if test=\"大众${requestScope.pageBean.pageNum != i}\"大众>26 <a href=\"大众${pageContext.request.contextPath}/FindAllWithPage?pageNum=${i}\公众>${i}</a> 27 </c:if> 28 </c:forEach>29 <a href=\"大众${pageContext.request.contextPath}/FindAllWithPage?pageNum=${requestScope.pageBean.pageNum+1}\公众>下一页</a> 30 </c:if>31 32 <%-- 如果当前页是末了一页,则只有上一页这个超链接显示,下一页没有 --%>33 <c:if test=\"大众${requestScope.pageBean.pageNum == requestScope.pageBean.totalPage}\"大众>34 <a href=\"大众${pageContext.request.contextPath}/FindAllWithPage?pageNum=${requestScope.pageBean.pageNum-1}\"大众>上一页</a>35 <c:forEach begin=\"大众${requestScope.pageBean.start}\公众 end=\"大众${requestScope.pageBean.end}\公众 step=\公众1\"大众 var=\公众i\"大众>36 <c:if test=\"大众${requestScope.pageBean.pageNum == i}\"大众>37 ${i}38 </c:if>39 <c:if test=\公众${requestScope.pageBean.pageNum != i}\"大众>40 <a href=\公众${pageContext.request.contextPath}/FindAllWithPage?pageNum=${i}\"大众>${i}</a> 41 </c:if> 42 </c:forEach>43 </c:if>44 <%--尾页 --%>45 <a href=\"大众${pageContext.request.contextPath}/FindAllWithPage?pageNum=${requestScope.pageBean.totalPage}\"大众>尾页</a>

六、总结

实在分页真的很大略,难点就在一个地方,javabean的构建,只要理清楚了pageBean中须要哪些属性,各种属性的浸染是什么,那么分页就so easy了。
还有一个便是在jsp中写分页导航时的逻辑,不要混乱了。
实在一点也不难,有兴趣的同学可以自己动手实现一下分页的功能。
对自己理解分页有很大的帮助,往后就在也不用到别人那里复制粘贴别人的分页代码了,自己也能写。
靠自己丰衣足食。

上一篇:深入学习JavaWeb(十): JDBC增编削查,C3P0连接池,dbutils的利用