我的struts分页算法的实现(1)

发表于:2007-06-11来源:作者:点击数: 标签:
说到分页算法,一般WEB 开发 都会用到,我只是在我的实现技术上用了struts框架,其实原理都一样的。看了网上相当多的分页算法,有对的也有好多是错的,更有好多是不太优化的。还有以前自己在augmentum做的一个分页算法,总结了一些不足。决定重新再写一个分

说到分页算法,一般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;

}

然后在按下一页或者上一页的时候需要如下函数处理:

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 {

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;

}

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;

}

}

在HTML中按下一页或者上一页的时候有如下代码:

<logic:equal name="page" property="hasNextPage" value="true">

<html:link page="/List.do?action=nextPage">

nextPage

</html:link>

</logic:equal>

<logic:equal name="page" property="hasPreviousPage" value="true">

<html:link page="/List.do?action=previousPage">

PreviousPage

</html:link>

</logic:equal>


共3页: 1 [2] [3] 下一页

原文转自:http://www.ltesting.net

评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
...