Edzy_Java

  BlogJava :: 首页 ::  ::  ::  :: 管理 ::
  58 随笔 :: 12 文章 :: 11 评论 :: 0 Trackbacks

这里我以从一个用户表中查询用户信息为例演示其用法:

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<usersList.size();i++)
   {
            UserEO userEO=(UserEO)usersList.get(i);%>
      <tr>
        <td><a href="view_user.do?id=<%=userEO.getId()%>"><%=userEO.getUsername()%></a></td>
        <td><%=userEO.getName()%></td>
        <td><%=userEO.getPhoneNumber()%></td>
        <td><%=userEO.getEmailBox()%></td>
        <td><%=userEO.getAddress()%></td>
        <td><%=userEO.getPostcode()%></td>
        </tr>
    <%}%>
    </table></td>
  </tr>
</table>

<!-- 显示分页工具栏 -->


<%=pageResultSet.getToolBar("list_users.do")%>


注意:
1、如果你觉得分页工具栏不能满足你的要求,可以用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.*;


/**
 * <p>Title: PageResultSet</p>
 *
 * <p>Description:分页类 </p>
 *
 * <p>Copyright: Copyright (c) 2004</p>
 *
 * <p>Company:youngor-studio(http://www.54youngor.com) </p>
 * @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:返回分页大小
     *
     * @return int
     */
    public int getPageSize() {
        return pageSize;
    }


    /**
     * getRowsCount:返回总记录行数
     *
     * @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;
    }


    /**
     * 第一页
     * @return boolean
     */
    public boolean isFirst() {
        return (curPage==1)?true:false;
    }


    /**
     * 第一页
     * @return boolean
     */
    public boolean isLast() {
        return (curPage==pageCount)?true:false;
    }
    /**
     * 获取当前页数据
     * @return Collection
     */
    public Collection getData() {
        Collection curData = null;
        if (data != null) {
            int start = (curPage - 1) * pageSize;
            int end = 0;
            if (start + pageSize > rowsCount)
                end = rowsCount;
            else
                end = start + pageSize;
            ArrayList arrayCurData = new ArrayList();
            ArrayList arrayData = null;
            Vector vectorCurData = new Vector();
            Vector vectorData = null;
            boolean isArray = true;
            if (data instanceof ArrayList) {
                arrayData = (ArrayList) data;
                isArray = true;
            } else if (data instanceof Vector) {
                vectorData = (Vector) data;
                isArray = false;
            }
            for (int i = start; i < end; i++) {
                if (isArray) {
                    arrayCurData.add(arrayData.get(i));
                } else {
                    vectorData.add(vectorData.elementAt(i));
                }
            }
            if (isArray) {
                curData = (Collection) arrayCurData;
            } else {
                curData = (Collection) vectorCurData;
            }
        }
        return curData;
    }
    /**
     * 获取工具条
     * @return String
     */
    public String getToolBar(String fileName){
        String temp="";
        if(fileName.indexOf("?")==-1)
        {
            temp="?";
        }
        else
        {
            temp="&";
        }
        String str="<form method='post' name='frmPage' action='"+fileName+"'>";
        str+="<p align='center'>";
        if(isFirst())
            str+="首页 上一页&nbsp;";
        else
        {
            str+="<a href='"+fileName+temp+"cur_page=1'>首页</a>&nbsp;";
            str+="<a href='"+fileName+temp+"cur_page="+(curPage-1)+"'>上一页</a>&nbsp;";
        }
        if(isLast())
            str+="下一页 尾页&nbsp;";
        else
        {
            str+="<a href='"+fileName+temp+"cur_page="+(curPage+1)+"'>下一页</a>&nbsp;";
            str+="<a href='"+fileName+temp+"cur_page="+pageCount+"'>尾页</a>&nbsp;";
        }
        str+="&nbsp;共<b>"+rowsCount+"</b>条记录&nbsp;";
        str+="&nbsp;转到<select name='page' onChange=\"location='"+fileName+temp+"cur_page='+this.options[this.selectedIndex].value\">";
        for(int i=1;i<=pageCount;i++)
        {
            if(i==curPage)
                str+="<option value='"+i+"' selected>第"+i+"页</option>";
            else
                str+="<option value='"+i+"'>第"+i+"页</option>";
        }
        str+="</select></p></form>";
        return str;
    }
}

posted on 2006-11-15 21:15 lbfeng 阅读(912) 评论(3)  编辑  收藏 所属分类: JSP&Servlet技术

评论

# re: 用JAVA实现一个jsp分页 2007-10-11 20:58 李贤
UserBO userBO=new UserBO();

UserBO 是什么类阿?
能给出代码么?

希望能尽快告诉我
  回复  更多评论
  

# re: 用JAVA实现一个jsp分页 2007-12-18 09:13 礼必风
显然,UserBO是一个JavaBean撒!  回复  更多评论
  

# re: 用JAVA实现一个jsp分页 2007-12-22 16:41 游客
你写的这个分页与OOP的思想结合不够,
建议:(1)写一个javaBean:Page.java其中包含主要的三个基本属性.
其中包含:
当前页currentPageNo,最后页lastPageNo,页内容pageContent(集合)
(2)写一个接口:PageIf.java规定几个其本页操作方法.
void Page getCurrentPage();
void prevPage();
void nextPage();
void lastPage();
void jumpToPage(int pageNo);
(3)写一个PageIf的实现类,可用spring进行配置.
PageImpl.java包含以下属性(要有set方法)
private String tableName;
private String className;
private int pageSize;//页大小
private Page page=new Page();
private Dao pageDao; //(通用dao)
方法的实现(略)
(4)写一个页控制器类,用servlet,struts,spring都可以,用以根据请求调用页
相应的操作方法.取得当前页page并放在session中,返回视图.
(5)写视图页,比如jsp,
<a href="page.do?operate=nextPage">下一页</a>
共${page.lastPageNo}页
  回复  更多评论
  


只有注册用户登录后才能发表评论。


网站导航: