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

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

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

    隨筆 - 6  文章 - 129  trackbacks - 0
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    常用鏈接

    留言簿(14)

    隨筆檔案(6)

    文章分類(467)

    文章檔案(423)

    相冊

    收藏夾(18)

    JAVA

    搜索

    •  

    積分與排名

    • 積分 - 825738
    • 排名 - 49

    最新評論

    閱讀排行榜

    評論排行榜

    Displaytag1.1支持在外部實現大數據量分頁。主要有兩種方式實現:

    Displaytag 1.1 offers two alternative ways for working with partial lists:

    • the first one uses the valuelist pattern, and requires that the object that you give to displaytag implements the org.displaytag.pagination.PaginatedList interface. You can pass this object to displaytag as an usual list, and it will extract paging and sorting information from it. This way is more recommended if you have to build your backend layer and you can easily follow this pattern.
    • a second way, recommended if you only have to use partial list for few tables that show a performance problem using full lists, is passing all the needed parameters as separate tag attributes (recors to be shown, page number, total number of records...)

    其中第二種方式看起來較為簡單,只需在<displaytag>中增加兩個屬性:partialList="true"size="resultSize"即可,但是在使用發現這種方式由于是在原來內存分頁的基礎上修改的,所以還是存在一些Bug(比如:分頁導航的值不會變......)

    所以這里介紹Displaytag推薦的第一種方式,即:
    實現org.displaytag.pagination.PaginatedListorg.displaytag.pagination.PaginatedList接口。

    實現PaginatedList接口:

    import  java.util.List;

    import
     org.displaytag.pagination.PaginatedList;
    import
     org.displaytag.properties.SortOrderEnum;

    /**
     * 分頁列表
     * 
     * 
    @author  John.Zhu
     * 
     
    */

    public   class  PageList  implements  PaginatedList  {
        
    /**
         * 每頁的列表
         
    */

        
    private  List list;

        
    /**
         * 當前頁碼
         
    */

        
    private   int  pageNumber  =   1 ;

        
    /**
         * 每頁記錄數 page size
         
    */

        
    private   int  objectsPerPage  =   15 ;

        
    /**
         * 總記錄數
         
    */

        
    private   int  fullListSize  =   0 ;

        
    private
     String sortCriterion;

        
    private
     SortOrderEnum sortDirection;

        
    private
     String searchId;

        
    public  List getList() 
    {
            
    return
     list;
        }


        
    public   void  setList(List list)  {
            
    this .list  =
     list;
        }


        
    public   int  getPageNumber()  {
            
    return
     pageNumber;
        }


        
    public   void  setPageNumber( int  pageNumber)  {
            
    this .pageNumber  =
     pageNumber;
        }


        
    public   int  getObjectsPerPage()  {
            
    return
     objectsPerPage;
        }


        
    public   void  setObjectsPerPage( int  objectsPerPage)  {
            
    this .objectsPerPage  =
     objectsPerPage;
        }


        
    public   int  getFullListSize()  {
            
    return
     fullListSize;
        }


        
    public   void  setFullListSize( int  fullListSize)  {
            
    this .fullListSize  =
     fullListSize;
        }


        
    public  String getSortCriterion()  {
            
    return
     sortCriterion;
        }


        
    public   void  setSortCriterion(String sortCriterion)  {
            
    this .sortCriterion  =
     sortCriterion;
        }


        
    public  SortOrderEnum getSortDirection()  {
            
    return
     sortDirection;
        }


        
    public   void  setSortDirection(SortOrderEnum sortDirection)  {
            
    this .sortDirection  =
     sortDirection;
        }


        
    public  String getSearchId()  {
            
    return
     searchId;
        }


        
    public   void  setSearchId(String searchId)  {
            
    this .searchId  =
     searchId;
        }


    }

    Contoller:
    /**
         * 分頁查詢
         * 
         * 
    @param  request
         * 
    @param
     response
         * 
    @return

         * 
    @throws  Exception
         
    */

        
    private  ModelAndView paging(HttpServletRequest request,
                HttpServletResponse response, ModelAndView mav) 
    throws  Exception 
    {
            
    //  獲取當前頁數,displaytag通過參數"page"傳遞這個值

                     int  pageNumber;
            
    if  (request.getParameter( " page " !=   null

                    
    &&   ! "" .equals(request.getParameter( " page " )))  {
                pageNumber 
    =  Integer.parseInt(request.getParameter( " page "
    ));
            }
      else   {
                pageNumber 
    =   1
    ;
            }

            PageList pageList 
    =   new  PageList();
            Map map 
    =  WebUtils.getParametersStartingWith(request,  " search_ "
    );
            Page page 
    =
     dao.query(map, pageNumber, PAGE_SIZE);
                    
    //  設置當前頁數

            pageList.setPageNumber(pageNumber);
                    
    //  設置當前頁列表

            pageList.setList(page.getResults());
                    
    //  設置page size

            pageList.setObjectsPerPage(PAGE_SIZE);
                    
    //  設置總頁數

            pageList.setFullListSize(page.getTotalCount());

            mav.addObject(
    " results "
    , pageList);

            
    return
     mav;
        }

    好了,現在直接在JSP上使用 displaytag就行了:
    < display:table  name ="${results}"  id ="row"  class ="simple nocol"  pagesize ="${pageSize}"  export ="true"  
                        decorator
    ="org.displaytag.decorator.TotalTableDecorator"
     
                        requestURI
    ="${pageContext.request.contextPath}/pageQuery.do?method=paging" >

                     
    < display:column  property ="date.time"  title ="日期"  format ="{0,date,yyyy-MM-dd}"  sortable ="false"   />
                    
    < display:column  property ="code"  title ="編碼"  group ="1"  sortable ="false"   />
                    
    < display:column  property ="name"  title ="名稱"  group ="1"  sortable ="false"   />
                     
    < display:column  property ="costTotal"  title ="總額(元)"  format ="{0,number,0,000}"  total ="true"  sortable ="false"   />

    </ display:table >
    本文轉自:http://www.tkk7.com/zJun/archive/2007/02/08/98703.html

    posted on 2007-09-15 10:21 Ke 閱讀(1676) 評論(2)  編輯  收藏 所屬分類: tag

    FeedBack:
    # re: Displaytag1.1支持在外部實現大數據量分頁 2011-06-09 17:34 liox
    request.getParameter( " page " )
    我的程序并沒有這個page參數,請問是如何配置的呢。。action.action?page=**你的page是通過這種方式得到的么?  回復  更多評論
      
    # re: Displaytag1.1支持在外部實現大數據量分頁 2011-06-17 16:57 rrr
    采用這種方法,分頁導航的值依然不會變.  回復  更多評論
      
    主站蜘蛛池模板: gogo免费在线观看| 亚洲中文字幕无码一久久区| 大地资源在线资源免费观看 | 羞羞视频免费网站含羞草| 亚洲一区二区三区高清| 亚洲午夜爱爱香蕉片| 成人免费视频观看无遮挡| 亚洲一区二区免费视频| 免费h视频在线观看| 特a级免费高清黄色片| 蜜桃传媒一区二区亚洲AV| 亚洲AV无码一区二区三区在线| 亚洲精品无码不卡在线播HE | 亚洲综合色7777情网站777| 亚洲午夜福利在线观看| 亚洲精品国产高清不卡在线| 免费观看一级毛片| 女性自慰aⅴ片高清免费| 免费精品国偷自产在线在线| 久久青草免费91线频观看站街| 国产黄在线播放免费观看| 美女又黄又免费的视频| 亚洲精品无码专区| 亚洲一线产区二线产区区| 亚洲国产成人精品无码区在线网站| 久久国产精品亚洲综合 | 国产综合免费精品久久久| 国产精品无码免费专区午夜| 男女作爱免费网站| 农村寡妇一级毛片免费看视频| 粉色视频免费入口| 日本一区二区在线免费观看| 女人裸身j部免费视频无遮挡| 日本高清免费中文在线看| 免费又黄又爽又猛大片午夜| 一级看片免费视频| 国产特黄一级一片免费| 中文在线观看免费网站| 久草免费福利视频| 最好看最新的中文字幕免费| xxxxwww免费|