<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://m.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
    采用這種方法,分頁導航的值依然不會變.  回復  更多評論
      
    主站蜘蛛池模板: 一级毛片免费全部播放| 2022国内精品免费福利视频| 国产真人无遮挡作爱免费视频 | 美腿丝袜亚洲综合| 一级毛片成人免费看a| 亚洲嫩模在线观看| 午夜高清免费在线观看| 中文在线免费看视频| 亚洲免费视频播放| 亚洲乱码中文字幕手机在线| 日本免费网站视频www区| 羞羞的视频在线免费观看| 亚洲嫩模在线观看| 亚洲第一黄片大全| 曰曰鲁夜夜免费播放视频 | 亚洲欧洲第一a在线观看| 日本免费人成视频播放| 午夜无码A级毛片免费视频| 亚洲av日韩av永久无码电影 | 女人被弄到高潮的免费视频| 国产免费黄色无码视频| 亚洲色图激情文学| 亚洲今日精彩视频| 黑人大战亚洲人精品一区| 四虎影院免费在线播放| 国产婷婷成人久久Av免费高清| 亚洲成a人片在线观看老师| 在线免费观看亚洲| 久久免费99精品国产自在现线| 亚洲天堂在线视频| 成人毛片手机版免费看| 日本高清免费观看| 国产va免费精品| 亚洲乱码日产精品一二三| 久久精品九九亚洲精品| 亚洲精品制服丝袜四区| 亚洲VA综合VA国产产VA中| 午夜a级成人免费毛片| 91成年人免费视频| 亚洲视频在线观看免费| 中文字幕乱码系列免费|