分頁功能的實現


一、分頁的思路

  這就是一個分頁導航,其中能得到的數據有

    totalRecord:總共員工數,數據庫中總的記錄數,這里有55條

    totalPage:總頁數,11頁

    pageSize:每頁顯示的記錄數,這里可以看到每頁顯示5條

    pageNum:當前頁為第幾頁,比如圖中就為第9頁,因為9是沒有超鏈接的,

    start:總共能顯示5頁,讓用戶進行點擊,7為起始頁

    end:11為能顯示的尾頁,也就是,如果用戶點擊第8頁,那么start就為6,end就為10,每次都只有5頁共點擊查詢。

  把這些數據封裝在一個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 }
View Code

 

 

 

三、在service層編寫業務邏輯代碼

User類是我們需要顯示的數據的封裝后的javabean。

四、Servlet中編寫控制代碼

五、JSP中顯示數據,構建分頁導航

  我做的導航圖的邏輯代碼

    顯示所有員工數量、總頁數

    首先超鏈接 

    如果當前頁為第一頁時,就沒有上一頁這個超鏈接顯示

    如果當前頁不是第一頁也不是最后一頁,則有上一頁和下一頁這個超鏈接顯示

    如果當前頁是最后一頁,則只有上一頁這個超鏈接顯示,下一頁沒有

    尾頁超鏈接

 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>
View Code

 

標明出處:https://www.cnblogs.com/whgk/p/6474396.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM