###实现了如下图的分页效果 ###思路:生成哪些页码,例如1-6页,2-7页,是由后台控制生成的。 ###假设我们决定生成的分页条,上面有 9 个超链接供点击。 ###并且我们的分页信息包含总页数,当前为第几页等信息,那么我们可以计算生成分页条页面。
/**
* 页面上的分页条数据
* @param tatal 分页条一共生成几条页码数据供点击
* @param pages 一共多少页数据
* @param pageNum 当前页是第几页
*/
private List<String> pagesBar(int total, int pages, int pageNum) {
List<String> list = new ArrayList<String>();
// 分页条第一个链接从几开始
int start = pageNum - total / 2;
if (start <= 1) {
start = 1;
}
// 分页条最后一个链接以几开始,注意此处减1,否则生成分页条数据个数大于total
int end = start + total - 1;
// 处理一些特殊情况,如分页条数据开头或者末尾处,保证一定会生成 total 条分页条数据超链接
if (end > pages) {
end = pages;
start = end - total + 1;
if (start <= 1) {
start = 1;
}
}
// start end 迭代,一共有 total 条数据
while (end >= start) {
list.add(String.valueOf(start));
start++;
}
return list;
}
###页面展现
<c:forEach items="${pagesBar }" var="page" >
<a class="page" href="javascript:turnPage('${page}');">${page}</a>
</c:forEach>