免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 7320 | 回复: 8
打印 上一主题 下一主题

用jsp进行数据分页显示的一个实现 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2003-08-20 10:57 |只看该作者 |倒序浏览
本文以循序渐进的方式给出了用jsp处理分页显示的一个可重用,易于移植的实现。

如果把与各种商业逻辑实体相对应的数据叫做"实体数据",那么分页显示逻辑要封装的就是控制实体数据的"控制数据"(下文中沿用这两种说法).

首先让我们构建一个PageControl对象将分页所涉及到的一些关键的"控制数据"予以封装.

aa-1.gif (2.82 KB, 下载次数: 152)

aa-1.gif

论坛徽章:
0
2 [报告]
发表于 2003-08-20 11:01 |只看该作者

用jsp进行数据分页显示的一个实现

具体说明如下:

1.public int curPage ; //当前是第几页
2.public int maxPage ; //一共有多少页
3.public int maxRowCount ; //一共有多少行
4.public int rowsPerPage ; //每页有多少行
5.public yourDataType yourdata ;//装载每页的数据
关于每页所要显示的"实体数据"的载体,其实现方式多种多样,比如说在IBM电子商务系统MPE中是以bean的形式,这是一种面向对象的实现,比较的简略的实现可用java.util.Vector等,为了避免分散对核心问题的的注意力,这里用youDataType予以抽象.


6.public void countMaxPage() {   //根据总行数计算总页数  
    if (this.maxRowCount % this.rowsPerPage==0){
       this.maxPage = this.maxRowCount/this.rowsPerPage;
    }else{
       this.maxPage = this.maxRowCount/this.rowsPerPage + 1;        
        }
    }
this.rowsPerPage其实应从配置文件中获得,这样做的好处是程序能在运行中读取从而实现动态(再)配置,简略的做法是直接写在程序中。


7.public PageControl(yourPersistenceLayer yourPL)
这是一个参数类型为yourPersistenceLayer的构造函数.PersistenceLayer是直接同数据库打交道的一层,不同的公司都有不同的实现,比如说Microsoft的ADO就可以看作是一PersistenceLayer,IBM在其MPE系统中也实现了一个庞大的PersistenceLayer,. 一种投机的做法是不要PersistenceLayer,或者可以说是淡化该层,这样做势必降低系统的稳定性,可重用性,可扩展性。具体可以参考附录文献.在这个构造函数中,有这样几个主要操作:    this.maxRowCount = yourPL.getAvailableCount();  //得到总行数
    this.yourdata    = yourPL.getResult();          //得到要显示于本页的数据
    this.countMaxPage();                         //计算总页数







关于this.yourdata这里还有一个细节:在从数据库中获取"实体数据"时,通常有两种方式A)一次性获取所有数据;(B)每次根据当前页号,获取本页的数据,将其它数据予以抛弃;考虑到数据往往是大量甚至是海量的,如果一次性的获取,那么这些数据必然大量占用服务器内存资源,使系统性能大大降低,因此建议使用方法(A)

接下来的工作就可以交给servlet和jsp了
在servlet的service()方法中只需进行如下操作:

PageControl  pageCtl = yourBusinessObject.listData(req.getParameter("jumpPage");
req.setAttribute("pageCtl",pageCtl);



说明:yourBusinessObject封装了商业逻辑,是位于Business Logic Layer中的一个对象,运用OOAD的方法,封装商业对象,在Persistent Layer之上组建坚实的Business Logic Layer同样是构建大型电子商务架构的关键所在。本文的关注点只是分页处理,暂不详细论述.


在每个想要实现翻页显示数据的jsp页面中,我们的工作也很简单,其代码是公式化的:

<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>;
<%}%>;




说明:
1.if(pageCtl.maxPage!=1)实现了这样一个逻辑:如果所取得数据不足一页,那么就不用进行翻页显示。
2.我们注意到<%@ include file="/yourpath/pageman.jsp"%>;这使得真正的翻页部分完全得到了重用.



那么pageman.jsp到底做了些什么呢?它实现了经常做翻页处理的人耳熟能详的逻辑
(A)第一页时不能再向前翻;
(B)最后一页时不能再向后翻;
同时能够进行页面任意跳转,具体代码如下:

每页<%=pageCtl.rowsPerPage%>;行
共<%=pageCtl.maxRowCount%>;行
第<%=pageCtl.curPage%>;页
共<%=pageCtl.maxPage%>;页

;
<%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>;页



在页面上会呈现出形如下图的外观,至于想要修饰美化,那是美工的工作所在。

aa-2.gif (1.7 KB, 下载次数: 140)

aa-2.gif

论坛徽章:
0
3 [报告]
发表于 2003-08-20 11:02 |只看该作者

用jsp进行数据分页显示的一个实现

最后附上用于页面跳转的javascript公共函数:

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>;

论坛徽章:
0
4 [报告]
发表于 2003-08-20 22:04 |只看该作者

用jsp进行数据分页显示的一个实现

好东东,俺帮你顶先。

论坛徽章:
0
5 [报告]
发表于 2003-08-21 12:54 |只看该作者

用jsp进行数据分页显示的一个实现

瓜瓜

论坛徽章:
0
6 [报告]
发表于 2003-08-23 20:20 |只看该作者

用jsp进行数据分页显示的一个实现

8错,顶
applelover 该用户已被删除
7 [报告]
发表于 2003-09-26 21:16 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
8 [报告]
发表于 2008-01-13 14:52 |只看该作者
好东西

论坛徽章:
0
9 [报告]
发表于 2008-02-02 14:27 |只看该作者
说实话,还没实际用上也不好说好不好!能否提供原代码来看看呢?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP