struts实现分页,目前最好的方法

struts实现分页,目前最好的方法

在做之前我们的头脑中要有一个大概的框架:也就是我们怎么样来
划分各个功能模块。一般来说一个分页功能框架至少要包含如下几个
部分(java class)(括号注释对应本实例中的类)
1:页面元素(Order.java)。也就是一个页面要显示的一条条的记录
2:数据(DataCollection.java)。对应一个javaBean,我看有不少前辈将获取数据与页面控制放在一起,
我本人认为这样做不好。一来逻辑不清楚,二来对于一个控制来说应是可重用的,但放在一起就不能重用了。
3:页面页面控制(PageController.java)。也就是对一个页面的定义
4:页面跳转的Action(PageAction.java).因为这个页面跳转相对来说比较简单我们可以直接继承ActionForward
来达到这个目的。
5:用来显示的View.(page.jsp)

*********************************
注:本实例是从一个客户定单中取数据
*********************************

下面的我就各个部分作一个简单的介绍
1:页面元素。也就是一个页面要显示的一条条的记录(Order.java)
这个Order.java没有多大意思它只是一个“定单”的定义
        private int orderID;           定单编号
        private String customerID;        客户编号
        private Date orderDate;                下单日期
***********************************************************
/*
* Created on 2004-9-14
*
* TODO To change the template for this generated file go to
* Window - Preferences - Java - Code Style - Code Templates
*/
package com.toad.pub;
import java.util.Date;
/**
* @author Administrator
*
* TODO To change the template for this generated type comment go to
* Window - Preferences - Java - Code Style - Code Templates
*/
public class Order {

        private int orderID;               
        private String customerID;
        private Date orderDate;
        /**
         *
         */
        public Order() {
                // TODO Auto-generated constructor stub
        }
        /**
         * @param orderID
         * @param customerID
         * @param orderDate
         */
        public Order(int orderID, String customerID, Date orderDate) {
                this.orderID = orderID;
                this.customerID = customerID;
                this.orderDate = orderDate;
        }
        /**
         * @return Returns the customerID.
         */
        public String getCustomerID() {
                return customerID;
        }
        /**
         * @param customerID The customerID to set.
         */
        public void setCustomerID(String customerID) {
                this.customerID = customerID;
        }
        /**
         * @return Returns the orderDate.
         */
        public Date getOrderDate() {
                return orderDate;
        }
        /**
         * @param orderDate The orderDate to set.
         */
        public void setOrderDate(Date orderDate) {
                this.orderDate = orderDate;
        }
        /**
         * @return Returns the orderID.
         */
        public int getOrderID() {
                return orderID;
        }
        /**
         * @param orderID The orderID to set.
         */
        public void setOrderID(int orderID) {
                this.orderID = orderID;
        }
***********************************************************
2:数据(DataCollection.java).这个部分有您可以依据个人情况来进行
自定义。我已有的环境中是用的连接池.
        private ArrayList list;  用来存放所查询到的数据
        private Connection con; 代表一个数据库连接。这个连接
是通过<jsp:setProperty../>传过来的。在接下来的view中我会作介绍
***********************************************************
/*
* Created on 2004-9-15
*
* TODO To change the template for this generated file go to
* Window - Preferences - Java - Code Style - Code Templates
*/
package com.toad.pub;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Date;
/**
* @author Administrator
*
* TODO To change the template for this generated type comment go to
* Window - Preferences - Java - Code Style - Code Templates
*/
public class DataCollection {

        private ArrayList list;
        private Connection con;
        /**
         *
         */
        public DataCollection() {
                list=new ArrayList();
        }
        /**
         * @return Returns the con.
         */
        public Connection getCon() {
                return con;
        }
        /**
         * @param con The con to set.
         */
        public void setCon(Connection con) {
                this.con = con;
        }
        /**
         * @return Returns the list.
         */
        public ArrayList getList() {
                return list;
        }
        /**
         * @param list The list to set.
         */
        public void setList() {
               
                if(this.con==null){
                        System.out.println("con is null!");
                        return;
                }
                String syntax="select orderid,customerid,orderdate from orders order by orderid asc";
                int orderID=0;
                String customerID=null;
                Date orderDate=null;
                ResultSet rs=null;
                PreparedStatement pst=null;
                try{
                        pst=con.prepareStatement(syntax);
                        rs=pst.executeQuery();
                        while(rs.next()){
                                orderID=rs.getInt(1);
                                customerID=rs.getString(2);
                                orderDate=rs.getDate(3);
                                list.add(new Order(orderID,customerID,orderDate));
                        }
                }catch(SQLException e){
                        System.out.println("SQLException occur at fetch datas !");
                }finally{
                        try{
                                rs.close();
                                con.close();
                        }catch(SQLException e){
                                System.out.println("SQLException occur at rs and con close() !");
                        }
                }
        }
}
***********************************************************
3:页面页面控制(PageController.java)
        private ArrayList allItems;        保存DataCollection中的list,也就是所有的数据
        private int pageNumber;                当前页的页号
        private int lastIndexOfPage;        当前页的最后一个item(Order)在allItems中的index
        private int itemsPerPage;        每一页的容量
        private int itemsInPage;        当前页的实际items(orders)
        private int lastPageNumber;        为allItems/iemsPerPage or allItems/iemsPerPage+1
        private boolean hasPrevious;        是否为第一页
        private boolean hasNext;        是来为最后一页
***********************************************************
/*
* Created on 2004-9-14
*
* TODO To change the template for this generated file go to
* Window - Preferences - Java - Code Style - Code Templates
*/
package com.toad.pub;
import java.util.ArrayList;

/**
* @author Administrator
*
* TODO To change the template for this generated type comment go to
* Window - Preferences - Java - Code Style - Code Templates
*/
public class PageController {
       
        private int pageNumber;
        private int lastIndexOfPage;
        private int itemsPerPage;
        private int itemsInPage;
        private int lastPageNumber;
        private boolean hasPrevious;
        private boolean hasNext;
        private ArrayList allItems;
        /**
         * @return Returns the allItems.
         */
        public ArrayList getAllItems() {
                return allItems;
        }
        /**
         * @param allItems The allItems to set.
         */
        public void setAllItems(ArrayList allItems) {
                this.allItems = allItems;
        }
        /**
         * @return Returns the hasNext.
         */
        public boolean isHasNext() {
                return hasNext;
        }
        /**
         * @param hasNext The hasNext to set.
         */
        public void setHasNext() {
                int items=pageNumber*itemsPerPage;
                if(items>=allItems.size()){
                        this.hasNext =false;
                }else{
                        this.hasNext=true;
                }
        }
        /**
         * @return Returns the hasPrevious.
         */
        public boolean isHasPrevious() {
                return hasPrevious;
        }
        /**
         * @param hasPrevious The hasPrevious to set.
         */
        public void setHasPrevious() {
                if(pageNumber==1){
                        this.hasPrevious=false;
                }else{
                        this.hasPrevious=true;
                }
        }
        /**
         * @return Returns the itemsInPage.
         */
        public int getItemsInPage() {
                return this.itemsInPage;
        }
        /**
         * @param itemsInPage The itemsInPage to set.
         */
        public void setItemsInPage() {
                int temp=pageNumber*itemsPerPage;
                if(temp<=allItems.size()){
                        this.itemsInPage=itemsPerPage;
                }else{
                        this.itemsInPage=( allItems.size() - ((pageNumber-1)*itemsPerPage ));
                }
        }
        /**
         * @return Returns the itemsPerPage.
         */
        public int getItemsPerPage() {
                return itemsPerPage;
        }
        /**
         * @param itemsPerPage The itemsPerPage to set.
         */
        public void setItemsPerPage(int itemsPerPage) {
                this.itemsPerPage = itemsPerPage;
        }
        /**
         * @return Returns the pageNumber.
         */
        public int getPageNumber() {
                return pageNumber;
        }
        /**
         * @param pageNumber The pageNumber to set.
         */
        public void setPageNumber(int pageNumber) {
                this.pageNumber = pageNumber;
        }
       
        /**
         * @return Returns the lastIndexOfPage.
         */
        public int getLastIndexOfPage() {
                return lastIndexOfPage;
        }
        /**
         * @param lastIndexOfPage The lastIndexOfPage to set.
         */
        public void setLastIndexOfPage() {
                this.lastIndexOfPage =(pageNumber -1)*itemsPerPage;
        }
       
        /**
         * @return Returns the lastPageNumber.
         */
        public int getLastPageNumber() {
                return lastPageNumber;
        }
        /**
         * @param lastPageNumber The lastPageNumber to set.
         */
        public void setLastPageNumber() {
                if(allItems.size()%itemsPerPage==0){
                        this.lastPageNumber =allItems.size()/itemsPerPage;
                }else{
                        this.lastPageNumber =allItems.size()/itemsPerPage+1;
                }
        }
}
***********************************************************
4:页面跳转的Action(PageAction.java).
请注意PageAction是直接继承于ActionForward
很简单:就是根据action=arg2.getParameter("action").trim();
的返回值来设定pageNubmer和与之相就的设定。
一定不能忘了调用 return super.execute(arg0, arg1, arg2, arg3);
***********************************************************
/*
* Created on 2004-9-14
*
* TODO To change the template for this generated file go to
* Window - Preferences - Java - Code Style - Code Templates
*/
package com.toad.pub;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.apache.struts.actions.ForwardAction;
import com.toad.pub.PageController;

/**
* @author Administrator
*
* TODO To change the template for this generated type comment go to
* Window - Preferences - Java - Code Style - Code Templates
*/
public class PageAction extends ForwardAction {
       
        /* (non-Javadoc)
         * @see org.apache.struts.action.Action#execute(org.apache.struts.action.ActionMapping, org.apache.struts.action.ActionForm, javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse)
         */
        public ActionForward execute(ActionMapping arg0, ActionForm arg1,
                        HttpServletRequest arg2, HttpServletResponse arg3) throws Exception {
                // TODO Auto-generated method stub
                String action=null;
                HttpSession session=arg2.getSession(true);
                action=arg2.getParameter("action").trim();
                PageController controller=(PageController)session.getAttribute("controller");
                int pageNumber=controller.getPageNumber();
                if(action.compareToIgnoreCase("next")==0){
                        ++pageNumber;
                }else if(action.compareToIgnoreCase("pervious")==0){
                        --pageNumber;
                }else if(action.compareToIgnoreCase("first")==0){
                        pageNumber=1;
                }else if(action.compareToIgnoreCase("last")==0){
                        pageNumber=controller.getLastPageNumber();
                }
                controller.setPageNumber(pageNumber);
                controller.setHasNext();
                controller.setHasPrevious();
                controller.setItemsInPage();
                controller.setLastIndexOfPage();
                return super.execute(arg0, arg1, arg2, arg3);
        }
}
***********************************************************
5:用来显示的View.(page.jsp)
***********************************************************
<%@ page language="java" %>
<%@ taglib prefix="html" uri="/WEB-INF/struts-html.tld"%>
<%@ taglib prefix="bean" uri="/WEB-INF/struts-bean.tld"%>
<%@ taglib prefix="logic" uri="/WEB-INF/struts-logic.tld"%>
//得到连接池对象
<bean:define id="conpool" name="pool" type="com.toad.util.ConnectionPool"></bean:define>
//定义一个javaBean同时设定数据(<% Data.setList();%>)
<jsp:useBean id="Data" class="com.toad.pub.DataCollection" scope="session">
        <jsp:setProperty name="Data" property="con" value="<%=conpool.getcon()%>"/>
        <% Data.setList();%>
</jsp:useBean>
//定义一个PageController同时进行初始化请注意调用顺序!
<logic:notEmpty name="Data" property="list">
        <jsp:useBean id="controller" class="com.toad.pub.PageController" scope="session">
            <jsp:setProperty name="controller" property="allItems" value="<%=Data.getList()%>"/>
                <jsp:setProperty name="controller" property="itemsPerPage" value="20"/>
                <jsp:setProperty name="controller" property="pageNumber" value="1"/>
                <%
                        controller.setHasNext();
                        controller.setHasPrevious();
                        controller.setItemsInPage();
                        controller.setLastIndexOfPage();
                        controller.setLastPageNumber();
                %>
        </jsp:useBean>
</logic:notEmpty>

<!DOCTYPE HTML PUBLIC "-//w3c//dtd html 4.0 transitional//en">
<html>
<head>
<title>Lomboz JSP</title>
</head>
<body bgcolor="#FFFFFF">
<%int i=0;%>
Page Number:<bean:write name="controller" property="pageNumber" />
<table width="100%">
<tr>
<th align='left'>Row Number</th>
<th align='left'>Order ID</th>
<th align='left'>Customer ID</th>
<th align='left'>Order Date</th>
</tr>
<logic:present name="controller" scope="session">
        <bean:define id="offset" name="controller" property="lastIndexOfPage" type="Integer"></bean:define>
        <bean:define id="length" name="controller" property="itemsInPage" type="Integer"></bean:define>
        <logic:iterate id="order" name="controller" property="allItems" offset="<%=offset.toString()%>" length="<%=length.toString()%>" type="com.toad.pub.Order">
                <tr>
                <td><%=++i%></td>
                <td><bean:write name="order" property="orderID" /></td>
                <td><bean:write name="order" property="customerID" /></td>
                <td><bean:write name="order" property="orderDate" /></td>
                </tr>
        </logic:iterate>
       
        <tr>
        <logic:notEqual name="controller" value="1" property="pageNumber" >
        <td><html:link page="/pageaction.do?action=first">First</html:link></td>
        </logic:notEqual>
        <logic:equal name="controller" property="hasPrevious" value="true">
        <td><html:link page="/pageaction.do?action=pervious">Previous</html:link></td>
        </logic:equal>

        <logic:equal name="controller" property="hasNext" value="true">
        <td><html:link page="/pageaction.do?action=next">Next</html:link></td>
        </logic:equal>

        <bean:define id="lastpagenumber" name="controller" property="lastPageNumber" type="Integer"></bean:define>
        <logic:notEqual name="controller" property="pageNumber" value="<%=lastpagenumber.toString()%>"  >
        <td><html:link page="/pageaction.do?action=last">Last</html:link></td>
        </logic:notEqual>
       
        </tr>
</logic:present>
</table>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
说明:<br>一、含演示数据库建立脚本(较简单)<br>二、使用Struts、Hibernate和display超简单的实现了分页,你不用在页面上再写很多<%%>和很多判断,简单到只需要几行语句:<br><html:form method="post" action="/displayList"><br> <display:table name="lst" cellspacing="0" border="1" cellpadding="0" requestURI="displayList.do" export="true"><br> <display:column property="id" title="编号" /><br> <display:column property="name" title="名字" /><br> <display:column property="age" title="年龄" /><br> </display:table><br> <pag:pagination name="pv" requestUri="displayList.do"></pag:pagination><br></html:form><br>这就是全部语句,不用写任何代码。<br>三、由于使用了display,所以自动实现了Excel | XML | CSV 的导出功能。<br>四、生成页面导航的样式是:<br>[首页/前一页] [后一页/尾页] 显示第1到1条 共3项 每页显示2项 共3页 第1页 GO<br>其中每页显示2项中的项操作人员可以随便改,“第1页”中的页号可以随便改,操作相当的灵活。我看到的样式暂只这一种,我想在display中应可以方便的改变导航样式,不行的话你就去修改display的标签源码,想改成什么样就改成什么样。<br><br>心得:<br>一、今天才明白使用Hibernate还有一个好处,你可以随便改数据库,你可以一会用oracle,一会用sqlserver,一会用mysql,总之你写成的代码换一种数据库,最多就是改一下那几个xml文件,个人感觉这才是java一个地方编写到处运行呢。<br>二、明白了使用标签的好处。<br><br>另提示一点:<br>打开测试用“http://localhost:8080/StrutsHibernateDisplay/displayList.do”,如果直接打开list.jsp会告诉你没有数据的。<br><br>代码是wenlong342的,我只是稍做修改,然后写了上面的说明文字。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值