Board logo

标题: 用jsp进行数据分页显示的一个实现 [打印本页]

作者: look_w    时间: 2018-7-11 08:28     标题: 用jsp进行数据分页显示的一个实现

本文以循序渐进的方式给出了用jsp处理分页显示的一个可重用,易于移植的实现。
如果把与各种商业逻辑实体相对应的数据叫做"实体数据",那么分页显示逻辑要封装的就是控制实体数据的"控制数据"(下文中沿用这两种说法).
首先让我们构建一个PageControl对象将分页所涉及到的一些关键的"控制数据"予以封装.具体说明如下:
关于this.yourdata这里还有一个细节:在从数据库中获取"实体数据"时,通常有两种方式A)一次性获取所有数据;(B)每次根据当前页号,获取本页的数据,将其它数据予以抛弃;考虑到数据往往是大量甚至是海量的,如果一次性的获取,那么这些数据必然大量占用服务器内存资源,使系统性能大大降低,因此建议使用方法(A)
接下来的工作就可以交给servlet和jsp了在servlet的service()方法中只需进行如下操作:
1
2
PageControl  pageCtl = yourBusinessObject.listData(req.getParameter("jumpPage"));
req.setAttribute("pageCtl",pageCtl);




说明:yourBusinessObject封装了商业逻辑,是位于Business Logic Layer中的一个对象,运用OOAD的方法,封装商业对象,在Persistent Layer之上组建坚实的Business Logic Layer同样是构建大型电子商务架构的关键所在。本文的关注点只是分页处理,暂不详细论述.      
在每个想要实现翻页显示数据的jsp页面中,我们的工作也很简单,其代码是公式化的:      
1
2
3
4
5
6
<jsp:useBean id="pageCtl" class="yourpackage.PageControl" scope="request"></jsp:useBean>
<%if(pageCtl.maxPage!=1)){%>
<form name="ageForm"  action="/servlet/yourpackage.yourservlet" method="post">
<%@ include file="/yourpath/pageman.jsp"%>
</form>
<%}%>




说明:             
那么pageman.jsp到底做了些什么呢?它实现了经常做翻页处理的人耳熟能详的逻辑        
(A)第一页时不能再向前翻;        
(B)最后一页时不能再向后翻;        
同时能够进行页面任意跳转,具体代码如下:      
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
每页<%=pageCtl.rowsPerPage%>行
共<%=pageCtl.maxRowCount%>行
第<%=pageCtl.curPage%>页
共<%=pageCtl.maxPage%>页
<BR>
<%if(pageCtl.curPage==1){ out.print(" 首页 上一页");   }else{  %>   
<A HREF="javascript:gotoPage(1)">首页</A>
<A HREF="javascript:gotoPage(<%=pageCtl.curPage-1%>)">上一页</A>
<%}%>
<%if(pageCtl.curPage==pageCtl.maxPage){ out.print("下一页 尾页");   }else{  %>   
<A HREF="javascript:gotoPage(<%=pageCtl.curPage+1%>)">下一页</A>
<A HREF="javascript:gotoPage(<%=pageCtl.maxPage%>)">尾页</A>
<%}%>
转到第<SELECT name="jumpPage" onchange="Jumping()">
     <% for(int i=1;i<=pageCtl.maxPage;i++)  {
     if (i== pageCtl.curPage){
     %>
     <OPTION selected value=<%=i%>><%=i%></OPTION>
     <%}else{%>
     <OPTION value=<%=i%>><%=i%></OPTION>
     <%}}%>   
     </SELECT>页




在页面上会呈现出形如下图的外观,至于想要修饰美化,那是美工的工作所在。
最后附上用于页面跳转的javascript公共函数:
1
2
3
4
5
6
7
8
9
function Jumping(){
  document.PageForm.submit();
  return ;
}
function gotoPage(pagenum){
  document.PageForm.jumpPage.value = pagenum;
  document.PageForm.submit();
  return ;
}




如果他们位于名为TurnPage.js的文件中,那么在每个要实现翻页数据显示的jsp页面中加上这样的引用:<SCRIPT Language="JavaScript"src="/yourPath/TurnPage.js"></SCRIPT>




欢迎光临 电子技术论坛_中国专业的电子工程师学习交流社区-中电网技术论坛 (http://bbs.eccn.com/) Powered by Discuz! 7.0.0