如何在Struts中进行分页处理

如何在Struts中进行分页处理

最近做Struts项目涉及分页处理。下面就结合项目谈谈如何在Struts中进行分页处理。

根据需要你可以选择一次读出所有数据然后再分页,以后每次分页不再读数据。另一种方法你可以每次只读出需要显示的数据,以后每次分页分别在读其他数据。两种方法本文都将简单介绍。

先介绍第一种,数据一次读入。适合数据量小的场合,首次装载页面会比较慢。

项目片断简介:项目中需要分页的页面是RES0011页面,相对应的有RES0011AC.java(Action)RES0011AF.java(ActionForm)RES0011.jsp共三个文件。

 

一、struts-config.xml文件中应做如下配置:

<form-beans>

<form-bean name="RES0011" type="com.apps.res.RES0011AF"/>

</form-beans>

<action-mappings>

    <action path="/RES0011"

                      type="com.apps.res.RES0011AC"

                      name="RES0011" scope="session"

                      validate="true" input="/pages/COMERROR.jsp">

                      <forward name="RES0011" path="RES0011.page" />

                      <forward name="RES0010" path="/RES0010.do"/>

                      <forward name="RES0012" path="/RES0012.do"/>

                      <forward name="RES0013" path="/RES0013.do"/>

                      <forward name="RES0030" path="/RES0030.do" />

                      <forward name="RES0040" path="/RES0040.do" />

                      <forward name="RES0050" path="/RES0050.do" />

                      <forward name="RES0060" path="/RES0060.do" />

                      <forward name="RES0070" path="/RES0070.do" />

                      <forward name="SCH0016" path="/SCH0016.do"/>

                      <forward name="SCH0070" path="/SCH0070.do" />

                   <forward name="SCH0080" path="/SCH0080.do"/>

    </action>          

</action-mappings>

解释:RES0011.page其实就是RES0011.jsp,项目中由于用到了StrutsTiles功能,所以和我们常见的页面有些不同。这里可不必深究,认为他是页面就可以了。其他的<forward>都是项目需要和分页无关,大家也可以不必深究。关键要注意scope一定要设置为session,因为我们的数据都要保存在session中。如果你设置成request,那你分页的数据就会丢失。

二、ActionForm中的相关变量

分页中我们需要以下几个变量:

开始的纪录数:beginRecordNo

每页显示的记录个数:recordDivNo

所有记录的总数:allRecordNo

ActionForm中建立这些变量并产生相应的getset方法。当然,数据库中的相关内容也要有相应的变量。比如一个User信息的ArrayListArrayList中放入一个HashMapKeyUserIDValueUserName。当然你可以放入自己想要的任何东西,或者DataBean

ActionFrom的代码片断如下:

           private String recordDivNo;

 

           private String beginRecordNo;

 

           private String allRecordNo;

           /**

            * @param string

            */

           public void setAllRecordNo(String string) {

                      allRecordNo = string;

           }

           /**

            * @return

            */

           public String getAllRecordNo() {

                      return allRecordNo;

           }

           /**

            * @return

            */

           public String getBeginRecordNo() {

                      return beginRecordNo;

           }

 

           /**

            * @param string

            */

           public void setBeginRecordNo(String string) {

                      beginRecordNo = string;

           }

 

           /**

            * @return

            */

           public String getRecordDivNo() {

                      return recordDivNo;

           }

 

           /**

            * @param string

            */

           public void setRecordDivNo(String string) {

                      recordDivNo = string;

           }

三、Jsp中如何利用“二”中所描述的变量

先在Jsp中从Form里取出相应的变量

<%

           RES0011AF formRes0011 = (RES0011AF)session.getAttribute("RES0011");

           int divNum;

           String recordDivNo;

           String beginRecordNo;

           int beginRecordNoInt;

           try {

                      divNum = Integer.parseInt(formRes0011.getDivNum());

                      recordDivNo = formRes0011.getRecordDivNo();

                      beginRecordNo = formRes0011.getBeginRecordNo();

                      if (divNum == 0) {

                                 divNum = Integer.parseInt(formRes0011.getAllRecordNo());

                      }

           }

           catch(Exception e) {

                      divNum = Integer.parseInt(formRes0011.getAllRecordNo());

                      recordDivNo = formRes0011.getAllRecordNo();

                      beginRecordNo = "1";

           }

           beginRecordNoInt = Integer.parseInt(beginRecordNo) - 1;

%>

然后在Struts标签中使用:

<logic:iterate id="RES0011ID" name="RES0011" property="revContents" offset="<%=beginRecordNoInt + ""%>" length="<%=recordDivNo%>" indexId="indexOut">

<html:link action="/RES0011" paramId="pageEvt" paramName="RES0011ID" paramProperty="devDay">

<%= indexOut.intValue() + 1 %>.<bean:write name="RES0011ID" property="devName"/><br>

           </html:link>

。。。。

</logic:iterate>

 

解释:属性revContents可以认为是你定义的数据库中的内容。比如说一个UserArrayList,象我们刚才描述的那样。其中devDay属性就是UserIDdevName属性就是UserName了。给出的代码是直接从Session中取出数据,当然更专业的办法是:

<bean:define id=" beginRecordNo " name=" RES0011" property=" beginRecordNo "/>

然后再用beginRecordNo

下面是翻页的Link代码片断:

<html:link action="/RES0011" paramId="pageEvt" paramName="RES0011" paramProperty="prePage">

           <bean:message key="rf.resComm.previousNew" arg0='<%=(String)session.getAttribute("SETTING_PAGE_NUM")%>'/>

</html:link> 

 

<html:link action="/RES0011" paramId="pageEvt" paramName="RES0011" paramProperty="nextPage">

           <bean:message key="rf.resComm.nextNew" arg0='<%=(String)session.getAttribute("SETTING_PAGE_NUM")%>'/>

</html:link> 

bean:message中传的参数是我的特殊需要——每页显示多少是根据一个配置文件设置的。所以要有一个参数。如果你不是这样你的MSG有可能就是“上一页”,“下一页”。属性prePagenextPage没有什么特别的东西你只要区别出是哪一个就可以了。此值可以写在ActionFormreset方法中固定。比如上一页是p,下一页是n。有人问如果没有前页或者后页怎么办?其实这个很简单,在ActionForm中在追加一个控制变量就可以了。最后的代码好像这样:

<logic:equal  name="RES0011" property="prePageFlag" value="N">

           <html:link action="/RES0011" paramId="pageEvt" paramName="RES0011" paramProperty="prePage">

                      <bean:message key="rf.resComm.previousNew" arg0='<%=(String)session.getAttribute("SETTING_PAGE_NUM")%>'/>

           </html:link> 

</logic:equal>

<logic:notEqual  name="RES0011" property="prePageFlag" value="N">

           <bean:message key="rf.resComm.previousNew" arg0='<%=(String)session.getAttribute("SETTING_PAGE_NUM")%>'/>

</logic:notEqual>

 

<logic:equal  name="RES0011" property="nextPageFlag" value="N">

           <html:link action="/RES0011" paramId="pageEvt" paramName="RES0011" paramProperty="nextPage">

                      <bean:message key="rf.resComm.nextNew" arg0='<%=(String)session.getAttribute("SETTING_PAGE_NUM")%>'/>

           </html:link> 

</logic:equal>

<logic:notEqual  name="RES0011" property="nextPageFlag" value="N">

<bean:message key="rf.resComm.nextNew" arg0='<%=(String)session.getAttribute("SETTING_PAGE_NUM")%>'/>-->

</logic:notEqual>

 

到此,Jsp的代码就差不多了。

四、Action中的逻辑过程

首先在页面初期化的时候进行数据的读出,设置相应的变量起始显示页码一般从0开始。然后是其他的一些初始化工作。然后相应页面的Link事件,每次相应将起始页码加每页数据个数,作相应的数据正确性检查。

代码片断:

 

                                 String pageEvt = request.getParameter("pageEvt");

//还记得我们在Jsp中定义的LinkID么,对,就是pageEvt

                                            if (pageEvt.equals("p")) {

//响应上一页

                                                       int ibeginNo = Integer.parseInt(res0011Form.getBeginRecordNo());

                                                       int iRecordDivNo = Integer.parseInt(res0011Form.getRecordDivNo());

                                                       res0011Form.setBeginRecordNo(ibeginNo - iRecordDivNo + "");

                                            } else if (pageEvt.equals("n")) {

//响应下一页

                                                       int ibeginNo = Integer.parseInt(res0011Form.getBeginRecordNo());

                                                       int iRecordDivNo = Integer.parseInt(res0011Form.getRecordDivNo());

                                                       res0011Form.setBeginRecordNo(ibeginNo + iRecordDivNo + "");

                                            } else {

//画面初始化,取得所有数据

                                                       res0011Form.setBeginRecordNo("1");

                                            }

return mapping.findForward(target);

 

 

 

 

第二种方法,一次仅读入页面显示的数据。对于大数据量的访问速度令人能够接受。

了解了第一种方法,第二种方法也就不难实现。ActionForm中的结构差不多。只是Jsp中的使用不需要offset属性了。数据有多少显示多少。根据BeginRecordNo来决定从哪里开始显示数据,每次从数据库中读取数据就可以了。

 

灵活运用你还可以把两种方案结合起来,比如每次只读出500条数据然后每页显示20条。这样减少了数据库的访问次数对于海量数据的检索能够提高用户的访问速度。

 

后记:第一次写技术文章,不尽之处大家海涵。本文虽以一个项目体会的形式写出但是欢迎大家的讨论和批评指正。由于版权的原因无法将所有代码公开,大家见谅。文章只围绕技术问题进行探讨和研究,索要原代码者,也请免开尊口。最后谢谢大家。

说明:<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的,我只是稍做修改,然后写了上面的说明文字。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值