개발 시 데이터 페이징은 필수입니다. 데이터 양이 너무 많아서 처리를 해야 합니다. 하지만 페이징을 위해서는 sql문의 한계를 활용하거나 jquery 플러그인을 사용하는 등 다양한 방법이 있습니다. 그러나 기본 논리가 모두 필요합니다.
여기에 Bean 객체의 코드와 보조 클래스를 게시하세요. 제가 진행하고 있는 프로젝트는 개인 홈페이지라 할 수 있는 개인 블로그입니다.
(기본 논리 코드의 일부만 게시됨)
Page.java
package cn.edu.ldu.util; public class Page { private int everyPage; //每页显示的数量 private int totalPage; //总页数 private int totalCount; //总数量 private int currentPage; //当前页 private int beginIndex; //起始页 private boolean hasPrepage; //是否有上一页 private boolean hasNextPage; //是否有下一页 public Page() { } public Page(int everyPage, int totalPage, int totalCount, int currentPage,int beginIndex, boolean hasPrepage, boolean hasNextPage) { this.everyPage = everyPage; this.totalPage = totalPage; this.totalCount = totalCount; this.currentPage = currentPage; this.beginIndex = beginIndex; this.hasPrepage = hasPrepage; this.hasNextPage = hasNextPage; } public int getEveryPage() { return everyPage; } public void setEveryPage(int everyPage) { this.everyPage = everyPage; } public int getTotalPage() { return totalPage; } public void setTotalPage(int totalPage) { this.totalPage = totalPage; } public int getTotalCount() { return totalCount; } public void setTotalCount(int totalCount) { this.totalCount = totalCount; } public int getCurrentPage() { return currentPage; } public void setCurrentPage(int currentPage) { this.currentPage = currentPage; } public int getBeginIndex() { return beginIndex; } public void setBeginIndex(int beginIndex) { this.beginIndex = beginIndex; } public boolean isHasPrepage() { return hasPrepage; } public void setHasPrepage(boolean hasPrepage) { this.hasPrepage = hasPrepage; } public boolean isHasNextPage() { return hasNextPage; } public void setHasNextPage(boolean hasNextPage) { this.hasNextPage = hasNextPage; } }
PageUtil.java
package cn.edu.ldu.util; public class PageUtil { //创建分页信息对象 public static Page createPage(int everyPage,int totalCount,int currentPage) { everyPage = getEveryPage(everyPage); currentPage = getCurrentPage(currentPage); int totalPage = getTotalPage(everyPage, totalCount); int beginIndex = getBeginIndex(everyPage, currentPage); boolean hasPrePage = getHasPrePage(currentPage); boolean hasNextPage = getHasNextPage(totalPage, currentPage); return new Page(everyPage, totalPage,totalCount, currentPage, beginIndex, hasPrePage, hasNextPage); } //获得每页显示记录数 public static int getEveryPage(int everyPage) { return everyPage == 0 ? 10 : everyPage; } //获得当前页 public static int getCurrentPage(int currentPage) { return currentPage == 0 ? 10 : currentPage; } //获得总页数 public static int getTotalPage(int everyPage,int totalCount) { int totalPage=0; //要判断每页是否满页,否则页数+1 if(totalCount!=0 && totalCount%everyPage==0) { totalPage=totalCount/everyPage; } else { totalPage=totalCount/everyPage+1; } return totalPage; } //获得起始位置 public static int getBeginIndex(int everyPage,int currentPage) { return everyPage*(currentPage-1); } //判断是否有上一页 public static boolean getHasPrePage(int currentPage) { return currentPage== 1 ? false : true; } //判断是否有下一页 public static boolean getHasNextPage(int totalPage, int currentPage) { return (currentPage == totalPage) || (totalPage == 0) ? false : true; } }
때마다 그냥 가야 해 그냥 전화해.
//传入每页显示的页数,总记录数,当前页 Page page=PageUtil.createPage(5, diaryDao.findAllCount(), currentPage);
위 내용은 모두의 학습에 도움이 되기를 바라며, PHP 중국어도 구독해 주시길 바랍니다. 웹사이트.
JSP 페이징의 간단한 구현과 관련된 더 많은 글은 PHP 중국어 홈페이지를 주목해주세요!