java分页工具类的使用方法
说明:曾经在网上看过花样繁多的分页,很多都号称如何通用,但很多时候往往不尽如人意:有在分页类中还加入URL地址信息的,有在分页类中还进行分页动作处理(此动作完全属于操作数据库方面的事情)的。现在好了,经本人总结与提炼:
无论你是否自己手动分页,还是借助了框架进行分页。此工具类都可以帮助你达到稳定的分页效果(包括导航页码功能),而且使用方法也相对简单:好了,废话少说,代码如下:
packagetest.dao; importjava.util.List; /** *用于分页的工具类 *@author莫取网名 */ publicclassPager{ privateList list;//对象记录结果集 privateinttotal=0;//总记录数 privateintlimit=20;//每页显示记录数 privateintpages=1;//总页数 privateintpageNumber=1;//当前页 privatebooleanisFirstPage=false;//是否为第一页 privatebooleanisLastPage=false;//是否为最后一页 privatebooleanhasPreviousPage=false;//是否有前一页 privatebooleanhasNextPage=false;//是否有下一页 privateintnavigatePages=8;//导航页码数 privateint[]navigatePageNumbers;//所有导航页号 publicPager(inttotal,intpageNumber){ init(total,pageNumber,limit); } publicPager(inttotal,intpageNumber,intlimit){ init(total,pageNumber,limit); } privatevoidinit(inttotal,intpageNumber,intlimit){ //设置基本参数 this.total=total; this.limit=limit; this.pages=(this.total-1)/this.limit+1; //根据输入可能错误的当前号码进行自动纠正 if(pageNumber<1){ this.pageNumber=1; }elseif(pageNumber>this.pages){ this.pageNumber=this.pages; }else{ this.pageNumber=pageNumber; } //基本参数设定之后进行导航页面的计算 calcNavigatePageNumbers(); //以及页面边界的判定 judgePageBoudary(); } /** *计算导航页 */ privatevoidcalcNavigatePageNumbers(){ //当总页数小于或等于导航页码数时 if(pages<=navigatePages){ navigatePageNumbers=newint[pages]; for(inti=0;i pages){ endNum=pages; //最后navigatePages页 for(inti=navigatePages-1;i>=0;i--){ navigatePageNumbers[i]=endNum--; } }else{ //所有中间页 for(inti=0;i 1; hasNextPage=pageNumber list){ this.list=list; } /** *得到当前页的内容 *@return{List} */ publicList getList(){ returnlist; } /** *得到记录总数 *@return{int} */ publicintgetTotal(){ returntotal; } /** *得到每页显示多少条记录 *@return{int} */ publicintgetLimit(){ returnlimit; } /** *得到页面总数 *@return{int} */ publicintgetPages(){ returnpages; } /** *得到当前页号 *@return{int} */ publicintgetPageNumber(){ returnpageNumber; } /** *得到所有导航页号 *@return{int[]} */ publicint[]getNavigatePageNumbers(){ returnnavigatePageNumbers; } publicbooleanisFirstPage(){ returnisFirstPage; } publicbooleanisLastPage(){ returnisLastPage; } publicbooleanhasPreviousPage(){ returnhasPreviousPage; } publicbooleanhasNextPage(){ returnhasNextPage; } publicStringtoString(){ StringBuffersb=newStringBuffer(); sb.append("[") .append("total=").append(total) .append(",pages=").append(pages) .append(",pageNumber=").append(pageNumber) .append(",limit=").append(limit) .append(",isFirstPage=").append(isFirstPage) .append(",isLastPage=").append(isLastPage) .append(",hasPreviousPage=").append(hasPreviousPage) .append(",hasNextPage=").append(hasNextPage) .append(",navigatePageNumbers="); intlen=navigatePageNumbers.length; if(len>0)sb.append(navigatePageNumbers[0]); for(inti=1;i 关于用法:使用步骤如下:
1).不管是否用了条件查询,首先count出相应的总条数
2).构造一个Pager类(关于limit参数可根据自身前台进行取舍)
3).根据构造好的Pager类获取已经自动纠正过的pageNumber参数,-1再乘个limit,做为实际要查询的第一条记录的位置
4).设置要查从起始位置开始,直到第limit条的所有记录.(如果手工分页,则也有可能第二个参数是结尾记录的位置偏移,具体情况视数据库而定)
5).将[条件]查询出的list设置入pager对象中并返回.
6).在展现层通过Servlet或Action或直接拿到这个pager对象即可使用,具体如何拼接url的事情,也应该交由展现层来完成即可。inttotalCount=Integer.valueOf(queryCount.uniqueResult().toString()); Pagerpager=newPager(totalCount,pageNumber,limit); queryList.setFirstResult((pager.getPageNumber()-1)*limit);//容错处理 queryList.setMaxResults(limit); pager.setList(queryList.list()); returnpager;上述代码是使用了hibernate的一个简单示例。如果你是手工分页,也按使用步骤来即可。
当然了,分页可以放在dao层来完成,也可以放在Service层来完成。而Servlet或Action则去调用service层的代码。个人认为:分页其实也是一种业务需要,因此,可以将其放在业务层。因为DAO层提供相应的[条件查询]list及[条件]统计count,在业务层完全可以根据自己的需要进行方法调用(只不过需要按既定的步骤来罢了,当然了,很多时候,业务都是有既定的流程步骤的)。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。