我每页显示一百条,每次分页显示数据时数据的编号总是从1开始,一直到100。这样显然不行,我希望实现动态的显示,编号根据页数的改变动态显示,比如第一页是1到100,第二页就是101-200这个样子。请高手指点!
这是我的分页代码:
package com.tv.entity;import java.util.List;/**
 * 保存分页信息
 * 
 * @author 大鸟
 * 
 */
@SuppressWarnings("unchecked")
public class PageInfo { private List list; // 要返回的某一页的记录列表 private Integer allRow; // 总记录数
private Integer totalPage; // 总页数
private Integer currentPage; // 当前页
private Integer pageSize; // 每页记录数 private boolean isFirstPage; // 是否为第一页
private boolean isLastPage; // 是否为最后一页
private boolean hasPreviousPage; // 是否有前一页
private boolean hasNextPage; // 是否有下一页
public List getList() {
return list;
} public void setList(List list) {
this.list = list;
} public Integer getAllRow() {
return allRow;
} public void setAllRow(Integer allRow) {
this.allRow = allRow;
} public Integer getTotalPage() {
return totalPage;
} public void setTotalPage(Integer totalPage) {
this.totalPage = totalPage;
} public Integer getCurrentPage() {
return currentPage;
} public void setCurrentPage(Integer currentPage) {
this.currentPage = currentPage;
} public Integer getPageSize() {
return pageSize;
} public void setPageSize(Integer pageSize) {
this.pageSize = pageSize;
} /**
 * 初始化分页信息
 */
public void init() {
this.isFirstPage = isFirstPage();
this.isLastPage = isLastPage();
this.hasPreviousPage = isHasPreviousPage();
this.hasNextPage = isHasNextPage();
} /**
 * 以下判断页的信息,只需getter方法(is方法)即可
 * 
 * @return
 */ public boolean isFirstPage() {
return currentPage == 1; // 如是当前页是第1页
} public boolean isLastPage() {
return currentPage == totalPage; // 如果当前页是最后一页
} public boolean isHasPreviousPage() {
return currentPage != 1; // 只要当前页不是第1页
} public boolean isHasNextPage() {
return currentPage != totalPage; // 只要当前页不是最后1页
} /**
 * 计算总页数,静态方法,供外部直接通过类名调用
 * 
 * @param pageSize
 *            每页记录数
 * @param allRow
 *            总记录数
 * @return 总页数
 */
public static int countTotalPage(final int pageSize, final int allRow) {
int totalPage = allRow % pageSize == 0 ? allRow / pageSize : allRow
/ pageSize + 1;
return totalPage;
} /**
 * 计算当前页开始记录
 * 
 * @param pageSize
 *            每页记录数
 * @param currentPage
 *            当前第几页
 * @return 当前页开始记录号
 */
public static int countOffset(final int pageSize, final int currentPage) {
final int offset = pageSize * (currentPage - 1);
return offset;
} /**
 * 计算当前页,若为0或者请求的URL中没有"?page=",则用1代替
 * 
 * @param page
 *            传入的参数(可能为空,即0,则返回1)
 * @return 当前页
 */
public static int countCurrentPage(int page) {
final int curPage = (page == 0 ? 1 : page);
return curPage;
}
}

解决方案 »

  1.   

    代码我没看.不过思路我想是这样的..
    你每次分页都会往后台传一个必须参数: 当前页数currPage.
    假设每页显示100条你是直接在后台定死的,而不是能过前台传过去的.
    1.你把当前页在返回数据list的时候也传回来(即提供get方法),然后你写你在迭代的时候.
    比如说:
      <c:forEach items="${list}" var="bean" varStat="n">
         序号:<c:out value="${(currPage-1)*100 + n.count}">
      </c:forEach>这段代码可能运行不通,不过你修改一下应该就可以,问题应该不大.
       思路就是:你将当前页传回到页面.然后每行的序列号等于(当前页-1)*100+该列在当前页的位置