phppage类封装分页功能_Javaweb的分页功能

53eb4d32d3b9c230198dc94564a70617.png

【55】

一、分页的思路

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

ca12a7f3537f0e8dca8a8f768d5da14c.png

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

    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方式得到。

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

1406637833dc55f74ed8964208d11370.png

代码:

import java.util.List;
  
   public class PageBean<T> {
       //已知数据
       private int pageNum;    //当前页,从请求那边传过来。
       private int pageSize;    //每页显示的数据条数。
       private int totalRecord;    //总的记录条数。查询数据库得到的数据
     
      //需要计算得来
      private int totalPage;    //总页数,通过totalRecord和pageSize计算可以得来
      //开始索引,也就是我们在数据库中要从第几行数据开始拿,有了startIndex和pageSize,
      //就知道了limit语句的两个数据,就能获得每页需要显示的数据了
      private int startIndex;        
          
      
      //将每页要显示的数据放在list集合中
      private List<T> list;
      
      //分页显示的页数,比如在页面上显示1,2,3,4,5页,start就为1,end就为5,这个也是算过来的
      private int start;
      private int end;
      
      //通过pageNum,pageSize,totalRecord计算得来tatalPage和startIndex
      //构造方法中将pageNum,pageSize,totalRecord获得
      public PageBean(int pageNum,int pageSize,int totalRecord) {
          this.pageNum = pageNum;
          this.pageSize = pageSize;
          this.totalRecord = totalRecord;
          
          //totalPage 总页数
          if(totalRecord%pageSize==0){
             //说明整除,正好每页显示pageSize条数据,没有多余一页要显示少于pageSize条数据的
              this.totalPage = totalRecord / pageSize;
          }else{
              //不整除,就要在加一页,来显示多余的数据。
              this.totalPage = totalRecord / pageSize +1;
          }
         //开始索引
          this.startIndex = (pageNum-1)*pageSize ;
          //显示5页,这里自己可以设置,想显示几页就自己通过下面算法修改
          this.start = 1;
         this.end = 5;
          //显示页数的算法
 
        if(totalPage <=5){
              //总页数都小于5,那么end就为总页数的值了。
              this.end = this.totalPage;
         }else{
              //总页数大于5,那么就要根据当前是第几页,来判断start和end为多少了,
              this.start = pageNum - 2;
              this.end = pageNum + 2;
             
              if(start < 0){
                  //比如当前页是第1页,或者第2页,那么就不如和这个规则,
                  this.start = 1;
                  this.end = 5;
              }
            if(end > this.totalPage){
                  //比如当前页是倒数第2页或者最后一页,也同样不符合上面这个规则
                 this.end = totalPage;
                  this.start = end - 5;
              }
          }
     }
 //get、set方法。
      public int getPageNum() {
          return pageNum;
     }
  
     public void setPageNum(int pageNum) {
         this.pageNum = pageNum;
     }
  
      public int getPageSize() {
          return pageSize;
      }
  
      public void setPageSize(int pageSize) {
         this.pageSize = pageSize;
      }

     public int getTotalRecord() {
          return totalRecord;
    }
  
    public void setTotalRecord(int totalRecord) {
         this.totalRecord = totalRecord;
      }
 
    public int getTotalPage() {
         return totalPage;
     }
  
      public void setTotalPage(int totalPage) {
         this.totalPage = totalPage;
    }

     public int getStartIndex() {
         return startIndex;
     }

     public void setStartIndex(int startIndex) {
        this.startIndex = startIndex;
     }
 
    public List<T> getList() {
         return list;
     }

     public void setList(List<T> list) {
         this.list = list;
    }
 
     public int getStart() {
         return start;
    }
 
     public void setStart(int start) {
        this.start = start;
     }

     public int getEnd() {
        return end;
     }

     public void setEnd(int end) {
        this.end = end;
    }
 }

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

  其实就是在该层将我们所需要的PageBean对象构建好,返回给上一层

24968848ea51b7e34891be8ec63f8257.png

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

四、Servlet中编写控制代码

9b16a7354171575749c586b318ab88ba.png

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

       因为将我们所有需要的数据都封装在了pageBean中,pageBean对象又在request域中,所以在jsp页面中,我们只需要拿到我们所需要的数据,进行显示即可,构造导航图需要注意的有一点,逻辑要搞清楚,想要显示什么不想显示什么,全屏自己控制了,只需要记得一点,在请求Servlet时,需要把请求的页码交给服务器。不然服务器不知道你要获得第几页的数据。

       我做的导航图的逻辑代码

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

       首先超链接 

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

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

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

       尾页超链接 

jsp代码:

<%-- 构建分页导航 --%>
       共有${requestScope.pageBean.totalRecord}个员工,共${requestScope.pageBean.totalPage }页,当前为${requestScope.pageBean.pageNum}页
        <br/>
        <a href="${pageContext.request.contextPath}/FindAllWithPage?pageNum=1">首页</a>
       <%--如果当前页为第一页时,就没有上一页这个超链接显示 --%>
      <c:if test="${requestScope.pageBean.pageNum ==1}">
      <c:forEach begin="${requestScope.pageBean.start}" end="${requestScope.pageBean.end}" step="1" var="i">
        <c:if test="${requestScope.pageBean.pageNum == i}">
         ${i}
         </c:if>                
           <c:if test="${requestScope.pageBean.pageNum != i}">
           <a href="${pageContext.request.contextPath}/FindAllWithPage?pageNum=${i}">${i}</a>                                        
            </c:if>                        
       </c:forEach>
                 <a href="${pageContext.request.contextPath}/FindAllWithPage?pageNum=${requestScope.pageBean.pageNum+1}">下一页</a>                    
             </c:if>
             
       <%--如果当前页不是第一页也不是最后一页,则有上一页和下一页这个超链接显示 --%>
         <c:if test="${requestScope.pageBean.pageNum > 1 && requestScope.pageBean.pageNum < requestScope.pageBean.totalPage}">
            <a href="${pageContext.request.contextPath}/FindAllWithPage?pageNum=${requestScope.pageBean.pageNum-1}">上一页</a>
         <c:forEach begin="${requestScope.pageBean.start}" end="${requestScope.pageBean.end}" step="1" var="i">    
             <c:if test="${requestScope.pageBean.pageNum == i}">
                    ${i}
             </c:if>            
              <c:if test="${requestScope.pageBean.pageNum != i}">
                    <a href="${pageContext.request.contextPath}/FindAllWithPage?pageNum=${i}">${i}</a>                                        
              </c:if>                        
         </c:forEach>
            <a href="${pageContext.request.contextPath}/FindAllWithPage?pageNum=${requestScope.pageBean.pageNum+1}">下一页</a>    
       </c:if>
             
        <%-- 如果当前页是最后一页,则只有上一页这个超链接显示,下一页没有 --%>
            <c:if test="${requestScope.pageBean.pageNum == requestScope.pageBean.totalPage}">
              <a href="${pageContext.request.contextPath}/FindAllWithPage?pageNum=${requestScope.pageBean.pageNum-1}">上一页</a>
            <c:forEach begin="${requestScope.pageBean.start}" end="${requestScope.pageBean.end}" step="1" var="i">
            <c:if test="${requestScope.pageBean.pageNum == i}">
                  ${i}
           </c:if>
           <c:if test="${requestScope.pageBean.pageNum != i}">
                 <a href="${pageContext.request.contextPath}/FindAllWithPage?pageNum=${i}">${i}</>                                        
           </c:if>                
         </c:forEach>
       </c:if>
       <%--尾页 --%>
    <a href="${pageContext.request.contextPath}/FindAllWithPage?pageNum=${requestScope.pageBean.totalPage}">尾页</a>

六、总结

   其实分页真的很简单,难点就在一个地方,javabean的构建,只要理清楚了pageBean中需要哪些属性,各种属性的作用是什么,那么分页就so easy了。还有一个就是在jsp中写分页导航时的逻辑,不要混乱了。

常见数据库分页:

1.oracle数据库分页
select * from (select a.*,rownum rc from 表名 where rownum<=endrow) a where a.rc>=startrow
2.DB2数据库分页
Select * from (select rownumber() over() as rc,a.* from (select * from 表名 order by列名) as a) where rc between startrow and endrow
3.SQL Server 2000数据库分页
Select top pagesize * from 表名 where 列名 not in(select top pagesize*page 列名 from 表名 order by列名) order by列名
4.SQL Server 2005数据库分页
Select * from (select 列名,row_number() over(order by 列名1) as 别名from 表名) as t where t.列名1>=startrow and t.列名1<=endrow
5.MySQL数据库分页
Select * from 表名 limit startrow,pagesize (Pagesize为每页显示的记录条数)

转载:

Java Web(十一) 分页功能的实现​www.cnblogs.com
e6b2495c7db316cf7d883d5f97f24690.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值