网站大量收购独家精品文档,联系QQ:2885784924

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

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
用jsp进行数据分页显示的一个实现

用jsp进行数据分页显示的一个实现 来源:中国IT实验室    本文以循序渐进的方式给出了用jsp处理分页显示的一个可重用,易于移植的实现。   如果把与各种商业逻辑实体相对应的数据叫做实体数据,那么分页显示逻辑要封装的就是控制实体数据的控制数据(下文中沿用这两种说法).   首先让我们构建一个PageControl对象将分页所涉及到的一些关键的控制数据予以封装.   具体说明如下:   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;   }   }   7. this.rowsPerPage其实应从配置文件中获得,这样做的好处是程序能在运行中读取从而实现动态(再)配置,简略的做法是直接写在程序中。   8. 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=PageForm action=/servlet/yourpackage.yourservlet method=post>   <%@ i

文档评论(0)

haocen + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档