<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Java學習

    java,spring,structs,hibernate,jsf,ireport,jfreechart,jasperreport,tomcat,jboss -----本博客已經搬家了,新的地址是 http://www.javaly.cn 如果有對文章有任何疑問或者有任何不懂的地方,歡迎到www.javaly.cn (Java樂園)指出,我會盡力幫助解決。一起進步

     

    在JSF中實現分頁(一)

    zhuan(http://www.steadyxp.com/archives/185.html)

        對于大多數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}中對應的方法,如果在這里調用了數據訪問邏輯,就會在只顯示一次頁面的情況下進行多次數據庫操作,也是相當的耗費資源的。

        所以我們需要有更好的分頁方式去解決以上問題,下一篇我將介紹另一種方法以改善這些問題。

    posted on 2009-03-09 15:50 找個美女做老婆 閱讀(271) 評論(0)  編輯  收藏


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     

    導航

    統計

    公告

    本blog已經搬到新家了, 新家:www.javaly.cn
     http://www.javaly.cn

    常用鏈接

    留言簿(6)

    隨筆檔案

    文章檔案

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 国产又黄又爽又刺激的免费网址| 成人免费视频一区二区| 亚洲视频免费在线看| 国产黄色片免费看| 91午夜精品亚洲一区二区三区| 免费a级毛片无码a∨性按摩| 120秒男女动态视频免费| mm1313亚洲国产精品无码试看 | 亚洲成a人片在线观看天堂无码| 亚洲精品二区国产综合野狼 | 1000部夫妻午夜免费| 久久久久高潮毛片免费全部播放 | 久久久无码精品亚洲日韩蜜桃| 国产免费观看网站| 88av免费观看| 性xxxxx免费视频播放 | 亚洲情A成黄在线观看动漫软件| 亚洲人成免费电影| 伊人久久亚洲综合影院首页| 精品无码专区亚洲| 国产99视频精品免费视频76| a级成人毛片免费图片| 日韩精品极品视频在线观看免费 | 一级毛片无遮挡免费全部| 亚洲中文字幕久久精品无码A | 亚洲AV无码国产精品色午友在线 | 亚洲va久久久噜噜噜久久天堂| 久久国产亚洲高清观看| 久久伊人亚洲AV无码网站| 日本亚洲成高清一区二区三区| 亚洲理论片在线中文字幕| 亚洲AV无码一区二区大桥未久| 一级人做人爰a全过程免费视频| 精品四虎免费观看国产高清午夜| 一区二区三区免费视频网站| 永久免费av无码网站yy| 无码人妻一区二区三区免费手机| 波多野结衣中文一区二区免费| 国产l精品国产亚洲区在线观看| 亚洲区视频在线观看| 国产成人久久精品亚洲小说|