zoukankan      html  css  js  c++  java
  • 分页功能实现

    分页功能的实现方法一:(https://home.cnblogs.com/u/whgk/)

    (从代码角度直接实现分页)

    分页思路:

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

            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页面中从域中获取需要的数据即可。

         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 }

    分页功能的实现方法二:pageHelper插件(只对后面的sql语句起作用)

    在SQL查询语句之前执行PageHelper.startPage(pageNum, pageSize);

    pageNum:当前页

    pageSize:每一页多少条记录

  • 相关阅读:
    django-搭建BBS关键点总结
    关于django中input标签中file类型以及开路由
    Bzoj1115 石子游戏Kam
    HDU1907 John
    HDU2509 Be the Winner
    洛谷P1082 同余方程
    POJ1065 Area
    Vijos1889 天真的因数分解
    Bzoj2440 完全平方数
    Bzoj2705 Longge的问题
  • 原文地址:https://www.cnblogs.com/newbieYi/p/7473518.html
Copyright © 2011-2022 走看看