网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > JAVA > 开源技术 > Struts > 我的struts分页算法的实现  

我的struts分页算法的实现

2006-11-11  作者:网管整理  来源:bitsCN.com  点评 投稿 收藏

    说到分页算法,一般WEB开发都会用到,我只是在我的实现技术上用了struts框架,其实原理都一样的。
看了网上相当多的分页算法,有对的也有好多是错的,更有好多是不太优化的。还有以前自己在augmentum做的一个分页算法,总结了一些不足。决定重新再写一个分页算法。
首先,应该写个bean来记录存储一些页面的属性
分页大致需要如下属性:

 private int currentPage = 1; // 当前页

 private int totalPages = 0; // 总页数

 private int pageRecorders = 5;// 每页5条数据 

 private int totalRows = 0; // 总数据数

 private int pageStartRow = 0;// 每页的起始数

 private int pageEndRow = 0; // 每页显示数据的终止数

 private boolean hasNextPage = false; // 是否有下一页

 private boolean hasPreviousPage = false; // 是否有前一页

网管网www_bitscn_com

 
 private int nextPage = 0;//下一页的页码
 
 private int previousPage = 0;//上一页的页码

然后这些属性之间是有联系的,我们可以在构造函数的时候就初始化一些属性
有两种方法:
一,根据总的页数,(假设当前页为1)
 public PageBean(int totalRows){
  this.totalRows = totalRows;
  this.currentPage = 1;
  hasPreviousPage = false;
  if ((totalRows % pageRecorders) == 0) {
   totalPages = totalRows / pageRecorders;
  } else {
   totalPages = totalRows / pageRecorders + 1;
  }
  if (totalRows >= pageRecorders) {
   hasNextPage = true;
   nextPage = 2;
   this.pageEndRow = pageRecorders; 中国网管联盟bitsCN.com
  } else {
   this.pageEndRow = totalRows;
   hasNextPage = false;
   nextPage = 1;
  }
   this.pageStartRow = 0;  
   previousPage = 1;
 }
然后在按下一页或者上一页的时候需要如下函数处理:
public void nextPage() {
  if(hasNextPage == true)
  currentPage = currentPage + 1;
  if ((currentPage - 1) > 0) {
   hasPreviousPage = true;
  } else {
   hasPreviousPage = false;
  }
  if (currentPage >= totalPages) {
   hasNextPage = false;
   this.nextPage = currentPage;
  } else { 中国网管联盟bitsCN.com
   hasNextPage = true;
   nextPage = currentPage+1;
  }
  this.pageStartRow = (currentPage -1) * pageRecorders;
  if(hasNextPage == true)
  this.pageEndRow = pageStartRow + 5;
  else{
   this.pageEndRow =this.totalPages;
  }
  previousPage = currentPage - 1;
 }
 
 public void previousPage() {
  if(hasPreviousPage == true)
  currentPage = currentPage - 1;
  if (currentPage == 0) {
   currentPage = 1;
  }
  if (currentPage >= totalPages) {
   hasNextPage = false;
  } else {
   hasNextPage = true; 网管联盟bitsCN_com
  }
  nextPage = currentPage + 1;
  if ((currentPage - 1) > 0) {
   hasPreviousPage = true;
   previousPage = currentPage - 1;
  } else {
   hasPreviousPage = false;
   previousPage = currentPage;
  }
  
  this.pageStartRow = (currentPage -1) * pageRecorders;
  if(hasNextPage == true)
  this.pageEndRow = pageStartRow + 5;
  else{
   this.pageEndRow =this.totalPages;
  }
 } 网管论坛bbs_bitsCN_com


TAGs   实现   算法   currentPage   queryString   queryCon   if   true      
 上一篇:没有了   下一篇:用标签库提高开发速度
我的struts分页算法的实现 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
最新推荐文章:
网管论坛交流: