日期:2014-05-16 浏览次数:20429 次
这里我以从一个用户表中查询用户信息为例演示其用法: 1.将PageResultSet.java文件编译成class文件并放入你的Web应用程序的WEB-INF/classes/com/youngor/util目录下,可以对包名做相应修改。 2.在你的Action类中: 先从业务处理逻辑类中取出数据(ArrayList或Vector格式) UserBO userBO=new UserBO(); Collection data=userBO.findUsers();//示例方法 再得到当前页curPage和每页记录数pageSize int curPage = Integer.parseInt(request.getParameter(“cur_page“)); int pageSize=15; 然后生成PageResultSet对象 PageResultSet dataList = new PageResultSet(data, curPage, pageSize); request.setAttribute("usersList", usersList); 3.在你的JSP页面中: <% PageResultSet pageResultSet=(PageResultSet)request.getAttribute("usersList"); ArrayList usersList=(ArrayList)pageResultSet.getData(); for(int i=0;i { UserEO userEO=(UserEO)usersList.get(i);%> <%=userEO.getUsername()%> <%=userEO.getName()%> <%=userEO.getPhoneNumber()%> <%=userEO.getEmailBox()%> <%=userEO.getAddress()%> <%=userEO.getPostcode()%> <%}%> <%=pageResultSet.getToolBar("list_users.do")%> 注意: 1、如果你觉得分页工具栏不能满足你的要求, q网管(Evp;育H9p, 可以用PageResultSet类中的公共方法 first()、previous()、next()、last()定制自己的工具栏,并且,你还可以在PageResultSet中定义多个样式的工具栏; 2、getToolBar(String url)方法接受带查询字符串的参数,比如“list_users.do?class_id=1“。 //PageResultSet.java package com.youngor.util; import java.util.*; /** * Title: PageResultSet * * Description:分页类 * * Copyright: Copyright (c) 2004 * * Company:youngor-studio(http://www.54youngor.com) * @author:伍维波 * @version 1.0 */ public class PageResultSet { /** * 分页数据 */ private Collection data = null; /** * 当前页 */ private int curPage; /** * 每页显示的记录数 */ private int pageSize; /** * 记录行数 */ private int rowsCount; /** * 页数 */ private int pageCount; public PageResultSet(Collection data) { this.data = data; this.curPage = 1; this.pageSize = 10; this.rowsCount = data.size(); this.pageCount = (int) Math.ceil((double) rowsCount / pageSize); } public PageResultSet(Collection data, int curPage) { this.data = data; this.curPage = curPage; this.pageSize = 10; this.rowsCount = data.size(); this.pageCount = (int) Math.ceil((double) rowsCount / pageSize); } public PageResultSet(Collection data, int curPage, int pageSize) { this.data = data; this.curPage = curPage; this.pageSize = pageSize; this.rowsCount = data.size(); this.pageCount = (int) Math.ceil((double) rowsCount / pageSize); } /** * getCurPage:返回当前的页数 * * @return int */ public int getCurPage() { return curPage; } /** * getPageSize: .vf]Y5{p}BuC"W 返回分页大小 * * @return int */ public int getPageSize() { return pageSize; } /** * getRowsCount:8NsAX教t$nT"TQ返回总记录行数 * * @return int */ public int getRowsCount() { return rowsCount; } /** * getPageCount:返回总页数 * * @return int */ public int getPageCount() { return pageCount; } /** * 第一页 * @return int */ public int first() { return 1; } /** * 最后一页 * @return int */ public int last() { return pageCount; } /** * 上一页 * @return int */ public int previous() { return (curPage - 1 < 1) ? 1 : curPage - 1; } /** * 下一页 * @return int */ public int next() { return (curPage + 1 > pageCount) ? pageCount : curPage + 1;