经典分页算法

这是一个仿照谷歌中的分页:

if(this.countpage>=6){

if (this.nowpage <= 4) {
   this.startindex = 1;
   this.endindex = this.nowpage + 2;
   if(this.endindex>this.countpage){
    this.endindex=this.countpage;
   }
   
  }else if(this.nowpage>4){
   this.startindex=this.nowpage-3;
   this.endindex=this.nowpage+2; 
   
   if(this.endindex>this.countpage){
    this.endindex=this.countpage;
    this.startindex=this.countpage-5;
   }
  }else{

this.startindex=1;
   if(this.endindex>this.countpage){
    this.endindex=this.countpage;
   }else{
    this.endindex=this.nowpage+2;
   }

 

}

分析:以下是以显示6个数页 为参考

1 2 3                 当前页是1    1 2 3
 
1 2 3 4               当前页是2     起始值1  未页 4

1 2 3 4 5             当前页是3     起始值1  未页 5

1 2 3 4 5 6           当前页是4     起始值1  未页 6   

从上图得知 当前页小于等于4时  起始页为1  末页=当前页+2

startindex=1;
endindex=nowpage+2;

注意: 求和值后的endindex 如果endindex大于总页数
  那么: this.endindex=this.countpage;

java的实现代码如下:
 
 if (this.nowpage <= 4) {  //判断小于等于4的情况
   this.startindex = 1;
   this.endindex = this.nowpage + 2;
   if(this.endindex>this.countpage){
    this.endindex=this.countpage;
   }
   
  }


当大于4时

2 3 4 5 6 7         当前页是5        起始值是2    未页 7
3 4 5 6 7 8         当前页是6        起始值是3    未页 8
4 5 6 7 8 9         当前页是7        起始值是4    未页 9
5 6 7 8 9 10        当前页是8        起始值是5    未页 10

从上图得知 当前页大于4时 

   1.当前页与尾页的差少于2    开始所以与当前页 差3
            endindex=nowpage+2;
            startindex=nowapge-3; 
   注意:求和值后的endindex,如果endindex大于总页数
            this.endindex=this.countpage;
     this.startindex=this.countpage-5;
java实现代码如下:
if(this.nowpage>4){ //大于4的情况
   this.startindex=this.nowpage-3;
   this.endindex=this.nowpage+2; 
   
   if(this.endindex>this.countpage){
    this.endindex=this.countpage;
    this.startindex=this.countpage-5;
   }

整合后的代码如下:
 // 计算索引位置
  if (this.nowpage <= 4) {  //判断小于等于4的情况
   this.startindex = 1;
   this.endindex = this.nowpage + 2;
   if(this.endindex>this.countpage){
    this.endindex=this.countpage;
   }
   
  }else if(this.nowpage>4){ //大于4的情况
   this.startindex=this.nowpage-3;
   this.endindex=this.nowpage+2; 
   
   if(this.endindex>this.countpage){
    this.endindex=this.countpage;
    this.startindex=this.countpage-5;
   }
  }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值