我的struts分页算法的实现(1)
文章作者 100test 发表时间 2007:03:14 16:35:40
来源 100Test.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. // 是否有前一页
 
 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.
  } else {
   this.pageEndRow = totalRows.
   hasNextPage = false.
   nextPage = 1.
  }
   this.pageStartRow = 0.  
   previousPage = 1.
 }