欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java web手寫實現(xiàn)分頁功能

 更新時間:2020年02月18日 10:16:55   作者:yechengchao  
這篇文章主要為大家詳細介紹了java web手寫實現(xiàn)分頁功能的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

現(xiàn)在很多流行的框架,都可以很快的把分頁效果做出來,但是作為一名程序員你必須得知道手寫分頁的流程:

場景效果:

一、分頁的思路

首先我們得知道寫分頁代碼的思路,保持思路清晰,才能行云流水的去寫代碼,其實不管是在寫什么代碼,思路,思想特別重要,先想好再動手,就會事半功倍!

先來分析SQL語句實現(xiàn)

Select * from product limit 0 ,5
Select * from product limit 5 ,5
Select * from product limit 10 ,5
Select * from product limit 15 ,5

#當前頁 起始值 每頁數(shù)據(jù)大小
1 0 5
2 5 5
3 10 5
4 15 5

結(jié)論:

(1)(當前頁-1)*(每頁數(shù)量)=起始值
(2)要想實現(xiàn)分頁,向服務(wù)端發(fā)起請求的時候,必須傳遞當前頁。

二、創(chuàng)建PageBean存放數(shù)據(jù)

這時候我們需要封裝一個包裝類,來封裝我們的分頁數(shù)據(jù)

package cn.itcast.store.domain;
import java.util.List;
/**
 * 存放分頁相關(guān)的數(shù)據(jù)
 *
 * @author yechengchao
 */
public class PageModel {
 //基本屬性
 /**當前頁數(shù),由用戶指定 */
 private int currentPageNum;
 /**每頁顯示的條數(shù),可以由用戶指定每頁顯示多少 */
 private int pageSize =5;
 /**總記錄條數(shù),數(shù)據(jù)庫查出來的 */
 private int totalRecords;
 /**總頁數(shù),計算出來的 */
 private int totalPageNum;
 /**每頁開始記錄的索引,計算出來的 (當前頁-1)*(每頁數(shù)量)=起始值 */
 private int startIndex;
 /**上一頁 */
 private int prePageNum;
 /**下一頁 */
 private int nextPageNum;
 /**已經(jīng)分好頁的結(jié)果集,存放我們查出來的結(jié)果集*/
 private List list;
 
 /**擴展屬性
 一共每頁顯示9個頁碼按鈕*/
 /**開始頁碼*/
 private int startPage;
 /**結(jié)束頁碼*/
 private int endPage;
 
 /**完善屬性*/
 private String url;
 

 /**要想使用我的分頁,必須給我兩個參數(shù)。一個是要看哪一頁,另一個是總記錄條數(shù)*/
 public PageModel(int currentPageNum,int totalRecords,int pageSize){
 this.currentPageNum = currentPageNum;
 this.totalRecords = totalRecords;
 this.pageSize=pageSize;
 
 //計算查詢記錄的開始索引
 startIndex = (currentPageNum-1)*pageSize;
 //計算總頁數(shù)
 totalPageNum = totalRecords%pageSize==0?(totalRecords/pageSize):(totalRecords/pageSize+1);
 
 //5
 startPage = currentPageNum - 4;
 //結(jié)束頁碼
 endPage = currentPageNum + 4;
 //看看總頁數(shù)夠不夠9頁
 if(totalPageNum>9){
 //超過了9頁
 if(startPage < 1){
 startPage = 1;
 endPage = startPage+8;
 }
 if(endPage>totalPageNum){
 endPage = totalPageNum;
 startPage = endPage-8;
 }
 }else{
 //不夠9頁
 startPage = 1;
 endPage = totalPageNum;
 }
 }

 public String getUrl() {
 return url;
 }

 public void setUrl(String url) {
 this.url = url;
 }
 
 public int getStartPage() {
 return startPage;
 }

 public void setStartPage(int startPage) {
 this.startPage = startPage;
 }

 public int getEndPage() {
 return endPage;
 }
 public void setEndPage(int endPage) {
 this.endPage = endPage;
 }
 public int getPrePageNum() {
 prePageNum = currentPageNum-1;
 if(prePageNum<1){
 prePageNum = 1;
 }
 return prePageNum;
 }
 public int getNextPageNum() {
 nextPageNum = currentPageNum+1;
 if(nextPageNum>totalPageNum){
 nextPageNum = totalPageNum;
 }
 return nextPageNum;
 }
 public int getCurrentPageNum() {
 return currentPageNum;
 }
 public void setCurrentPageNum(int currentPageNum) {
 this.currentPageNum = currentPageNum;
 }
 public int getPageSize() {
 return pageSize;
 }
 public void setPageSize(int pageSize) {
 this.pageSize = pageSize;
 }
 public int getTotalRecords() {
 return totalRecords;
 }
 public void setTotalRecords(int totalRecords) {
 this.totalRecords = totalRecords;
 }
 public int getTotalPageNum() {
 return totalPageNum;
 }
 public void setTotalPageNum(int totalPageNum) {
 this.totalPageNum = totalPageNum;
 }
 public int getStartIndex() {
 return startIndex;
 }
 public void setStartIndex(int startIndex) {
 this.startIndex = startIndex;
 }
 public void setPrePageNum(int prePageNum) {
 this.prePageNum = prePageNum;
 }
 public void setNextPageNum(int nextPageNum) {
 this.nextPageNum = nextPageNum;
 }
 public List getList() {
 return list;
 }
 public void setList(List list) {
 this.list = list;
 }
}

三、在servlet編寫控制代碼

首先用戶發(fā)送請求,帶上當前頁數(shù),在這表調(diào)用業(yè)務(wù)層的代碼,把以分頁的形式查詢商品,再把商品查詢出來之后賦值給我們創(chuàng)建的pageModel對象,這時候把這個對象傳到前端頁面,就可以把值取出來,實現(xiàn)分頁。

public String findProductByCidWithPage(HttpServletRequest request, HttpServletResponse response) throws Exception {
 //獲取cid,num
 String cid=request.getParameter("cid");
 int curNum=Integer.parseInt(request.getParameter("num"));
 //調(diào)用業(yè)務(wù)層的功能:以分頁的形式查詢當前頁類別下商品信息
 //返回PageModel對象(1當前頁商品信息2分頁3 url)
 ProductService productService=new ProductServiceImp();
 PageModel pm=productService.findProductByCidWithPage(cid,curNum);
 //將PageModel對象放入request
 request.setAttribute("page", pm);
 //轉(zhuǎn)發(fā)到/jsp/product_list.jsp
 return "/jsp/product_list.jsp";
 }

四、業(yè)務(wù)層service編寫業(yè)務(wù)邏輯代碼

當調(diào)用業(yè)務(wù)層的業(yè)務(wù)邏輯的時候,在這邊我們是通過Dao層把我們要查詢的商品查詢出來用一個list接收,再傳給pageModel的屬性list,這時候就把整個pageModel對象傳回去,這邊主要是調(diào)用Dao層查詢和 關(guān)聯(lián)集合,關(guān)聯(lián)URL。

public PageModel findProductByCidWithPage(String cid, int curNum) throws Exception {
 //1 創(chuàng)建pageModel對象 目的:計算分頁參數(shù)
 
 //統(tǒng)計當前分類下商品的個數(shù) select count(*) from product where cid=?
 int totalRecords=productDao.findtotalRecords(cid);
 PageModel pageModel=new PageModel(curNum, totalRecords, 12);
 //2.關(guān)聯(lián)集合 select * form product where cid=? limit ?,?
 List list=productDao.findProductByCidWithPage(cid,pageModel.getStartIndex(),pageModel.getPageSize());
 pageModel.setList(list);
 //3.關(guān)聯(lián)url
 pageModel.setUrl("ProductServlet?method=findProductByCidWithPage&cid="+cid);
 return pageModel;
 }

五、Dao層操作數(shù)據(jù)庫

為什么我們要在最開始分析sql語句,最根源就是在這邊查詢數(shù)據(jù)庫,我們需要把起始頁和分頁大小傳進去。

public List findProductByCidWithPage(String cid, int startIndex, int pageSize) throws Exception {
 String sql="select * from product where cid=? limit ?,?";
 QueryRunner qr=new QueryRunner(JDBCUtils.getDataSource());
 return qr.query(sql, new BeanListHandler<Product>(Product.class),cid,startIndex,pageSize);
 }

六、前端頁面,顯示分頁

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
 <%--分頁顯示的開始 --%>
 <div style="text-align:center">
 共${page.totalPageNum}頁/第${page.currentPageNum}頁
 
 <a href="${pageContext.request.contextPath}/${page.url}&num=1" rel="external nofollow" >首頁</a>
 <a href="${pageContext.request.contextPath}/${page.url}&num=${page.prePageNum}" rel="external nofollow" >上一頁</a>
 <%--顯示的頁碼,使用forEach遍歷顯示的頁面 --%>
 <c:forEach begin="${page.startPage}" end="${page.endPage}" var="pagenum">
 <a href="${pageContext.request.contextPath}/${page.url}&num=${pagenum}" rel="external nofollow" >${pagenum}</a>
 </c:forEach>
 
 <a href="${pageContext.request.contextPath}/${page.url}&num=${page.nextPageNum}" rel="external nofollow" >下一頁</a>
 <a href="${pageContext.request.contextPath}/${page.url}&num=${page.totalPageNum}" rel="external nofollow" >末頁</a>
 <input type="text" id="pagenum" name="pagenum" size="1"/><input type="button" value="前往" onclick="jump()" />
 <script type="text/javascript">
 function jump(){
 var totalpage = ${page.totalPageNum};
 var pagenum = document.getElementById("pagenum").value;
 //判斷輸入的是一個數(shù)字
 var reg =/^[1-9][0-9]{0,1}$/;
 if(!reg.test(pagenum)){
 //不是一個有效數(shù)字
 alert("請輸入符合規(guī)定的數(shù)字");
 return ;
 }
 //判斷輸入的數(shù)字不能大于總頁數(shù)
 if(parseInt(pagenum)>parseInt(totalpage)){
 //超過了總頁數(shù)
 alert("不能大于總頁數(shù)");
 return;
 }
 //轉(zhuǎn)向分頁顯示的Servlet
 window.location.href="${pageContext.request.contextPath}/${page.url}&num=" rel="external nofollow" +pagenum;
 }
 </script>
 </div>
 <%--分頁顯示的結(jié)束--%>

因為將我們所有需要的數(shù)據(jù)都封裝在了pageModel中,pageModel對象又在request域中,所以在jsp頁面中,我們只需要拿到我們所需要的數(shù)據(jù),進行顯示即可,構(gòu)造導(dǎo)航圖需要注意的有一點,邏輯要搞清楚,想要顯示什么不想顯示什么,全屏自己控制了,只需要記得一點,在請求Servlet時,需要把請求的頁碼交給服務(wù)器。不然服務(wù)器不知道你要獲得第幾頁的數(shù)據(jù)。

總結(jié)

其實分頁也不太難,一個難點就是javaBean的構(gòu)建,只要弄清楚pageModel里面需要哪些屬性,各種屬性的作用是什么,就會很清晰了。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 如何在Java中調(diào)用python文件執(zhí)行詳解

    如何在Java中調(diào)用python文件執(zhí)行詳解

    豐富的第三方庫使得python非常適合用于進行數(shù)據(jù)分析,最近在項目中就涉及到j(luò)ava調(diào)用python實現(xiàn)的算法,下面這篇文章主要給大家介紹了關(guān)于如何在Java中調(diào)用python文件執(zhí)行的相關(guān)資料,需要的朋友可以參考下
    2022-05-05
  • Java實現(xiàn)將word轉(zhuǎn)換為html的方法示例【doc與docx格式】

    Java實現(xiàn)將word轉(zhuǎn)換為html的方法示例【doc與docx格式】

    這篇文章主要介紹了Java實現(xiàn)將word轉(zhuǎn)換為html的方法,結(jié)合實例形式分析了java針對doc與docx格式文件的相關(guān)轉(zhuǎn)換操作技巧,需要的朋友可以參考下
    2019-03-03
  • 支票金額大寫轉(zhuǎn)換示例(金額大寫轉(zhuǎn)換器)

    支票金額大寫轉(zhuǎn)換示例(金額大寫轉(zhuǎn)換器)

    這篇文章主要介紹了支票金額大寫轉(zhuǎn)換示例(金額大寫轉(zhuǎn)換器),需要的朋友可以參考下
    2014-02-02
  • Java struts2捕獲404錯誤的方法匯總

    Java struts2捕獲404錯誤的方法匯總

    這篇文章主要為大家詳細匯總了Java struts2捕獲404錯誤的常用方法,感興趣的小伙伴們可以參考一下
    2016-05-05
  • 詳解path和classpath的區(qū)別

    詳解path和classpath的區(qū)別

    這篇文章主要介紹了詳解path和classpath的區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • SpringMVC+Spring+Mybatis實現(xiàn)支付寶支付功能的示例代碼

    SpringMVC+Spring+Mybatis實現(xiàn)支付寶支付功能的示例代碼

    這篇文章主要介紹了SpringMVC+Spring+Mybatis實現(xiàn)支付寶支付功能的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • Java實現(xiàn)注冊登錄與郵箱發(fā)送賬號驗證激活功能

    Java實現(xiàn)注冊登錄與郵箱發(fā)送賬號驗證激活功能

    這篇文章主要介紹了Java實現(xiàn)注冊登錄與郵箱發(fā)送賬號驗證激活功能,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-12-12
  • Java反射機制詳解

    Java反射機制詳解

    Java的反射機制是在運行狀態(tài)中,對于任何一個類,都可以知道這個類的所有屬性和方法,對于任何一個對象,都可以調(diào)用它所有的方法和屬性,修改部分類型信息。本文就來詳細講講Java反射機制的使用
    2022-07-07
  • Java實現(xiàn)支付對接常用加密方式的示例代碼

    Java實現(xiàn)支付對接常用加密方式的示例代碼

    這篇文章主要為大家詳細介紹了Java如何實現(xiàn)支付對接時常用加密方式,文中的示例代碼講解詳細,對我們學(xué)習(xí)Java有一點幫助,需要的可以參考一下
    2023-02-02
  • SpringMVC4.3?HttpMessageConverter接口實現(xiàn)源碼分析

    SpringMVC4.3?HttpMessageConverter接口實現(xiàn)源碼分析

    這篇文章主要為大家介紹了SpringMVC4.3?HttpMessageConverter接口實現(xiàn)源碼分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09

最新評論