JSF,如何实现分页?
   分页中,怎么实现排序,可以按照自己的意愿进行排序??

解决方案 »

  1.   

     如果是排序,可以用 dataTable实现,具体代码如下:
        对于大多数Web应用,分页都是必不可少的功能,当然在JSF中也一样,我在这里用两篇文章介绍两种方法来展示一下,如何在JSF中实现分页。
    本文假定你已经对JSF有了一些简单的了解,懂得基本配置和使用,并建立起一个blank项目。    
    Myfaces是Apache基金会中的一个一级项目,除了实现JSF标准外,做了很多的扩展工作,在Myfaces包中有一个扩展包Tomahawk,
    我们将主要使用其中的两个Component实现分页:一个是<t:dataTable>,另一个
    是<t:dataScroller>,在第一篇里面,我们简易的组合这两个Component来实现一种简单,但并不高效的分页。     下面的例子来自于Myfaces-Sample,我省去了其中和分页逻辑无关的内容,详细的例子可以下载Myfaces-Sample包或者访问http://www.irian.at/myfaces/home.jsf 查看。     第一部分:dataTable<t:dataTable id=”data”                  var=”car”                  value=”#{pagedSort.cars}”                  rows=”10″>    ……</t:dataTable>在这一部分中,dataTable绑定了一个backing bean -
    pagedSort中的cars属性,我们可以在这个属性中加入数据访问逻辑,从数据库或者其他来源取得用于显示的数据。比如我们可以通过
    Hibernate获取一个List,其中包含有我们用于显示的POJOs。注意,dataTable中的rows属性指的是每页的行数,是必须指定的,否则是无法进行分页的,如果在项目中会使用固定行数的分页,建议把这个
    值写在BaseBackingBean中,并暴露一个property,供页面调用,所以每次在页面中就可以这么写#
    {backingBean.pageSize}。 第二部分:dataScroller    <t:dataScroller id=”scroll_1″                        for=”data”                        fastStep=”10″                        paginator=”true”                        paginatorMaxPages=”9″>            <f:facet name=”first” >                <t:graphicImage url=”images/arrow-first.gif” border=”1″ />            </f:facet>            <f:facet name=”last”>                <t:graphicImage url=”images/arrow-last.gif” border=”1″ />            </f:facet>            <f:facet name=”previous”>                <t:graphicImage url=”images/arrow-previous.gif” border=”1″ />            </f:facet>            <f:facet name=”next”>                <t:graphicImage url=”images/arrow-next.gif” border=”1″ />            </f:facet>            <f:facet name=”fastforward”>                <t:graphicImage url=”images/arrow-ff.gif” border=”1″ />            </f:facet>            <f:facet name=”fastrewind”>                <t:graphicImage url=”images/arrow-fr.gif” border=”1″ />            </f:facet>        </t:dataScroller>   
    这里定义了我们用于分页的<t:dataScroller>,最主要的是配置该分页Component针对哪个dataTable进行分页的
    “for”属性,该属性与dataTable绑定,并对其进行分页,在这里,绑定了第一部分中的id=”data”的dataTable,下面有很多的&
    lt;t:facet>是指定分页的导航样式的,这里使用了图片作为导航,可以把他们改成文字形式的导航。   
    当然这只是最简单,也是一种不推荐的分页方式,因为在每次进行分页的时候,将会从数据库中取回所有的记录放入List中,然后,dataScroller
    在对这个List进行分页,如果在数据量很大的情况下,这种方式显然是不符合要求的,假设每条记录占用1k内存,数据库中有100万条记录,每次要把这个
    List全部读取出来将占用1G内存。我们需要一种Load on demand方式的读取,也就是只在需要查看某页的时候读取该页的数据。    另外一方面,JSF的生命周期中有多个阶段会调用到#{pagedSort.cars}中对应的方法,如果在这里调用了数据访问逻辑,就会在只显示一次页面的情况
    下进行多次数据库操作,也是相当的耗费资源的。    所以我们需要有更好的分页方式去解决以上问题,下一篇我将介绍另一种方法以改善这些问题。  上面是我在http://www.javaly.cn/javahome/java/content.detail/%E5%9C%A8JSF%E4%B8%AD%E5%AE%9E%E7%8E%B0%E5%88%86%E9%A1%B5%EF%BC%88%E4%B8%80%EF%BC%89/fdc1ed6c217af57f01219e9bcaef00f0.faces 转过来的,这里说明文章来源Java乐园
      

  2.   

    具体的排序,你可以在数据库里实现,也就是在你查询数据的时候,对所要进行排序的字段进行排序下就是了
     比如 你所查询的数据有一个date的兰位,你需要根据时间进行排序,假如是按时间,从后到前的排序,那么在
    你在取数据的时候,在sql语句后面 加上  order by date
      整个的sql : select ........ from xxx where  [xx = 'xxxx'] order by date desc 
      

  3.   

     上面的是在数据库里实现排序,如果想在代码里实现排序,这个也是可行的,我以前的代码,现在找不到了,以后找到了再给你,你也可以到我的Blog问我(www.javaly.cn), 你可以把你的联系方式给我,我找到了发给你