久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

ET Limit方式的分頁查詢 AJAX AJAX

 funronglei 2006-12-09

1.Limit
默認的情況下eXtremeTable取得所有的結(jié)果集然后處理Beans集合,,這樣的好處是 你可以隨意進行排序,、過濾和分頁操作,。
你只需要組裝Beans集合并讓eXtremeTable知道如何 然而在查詢結(jié)果較大,,可以考慮使用數(shù)據(jù)庫端分頁的方案,。此時,,eXtremeTable
會使用Limit對象向Action/Controller傳遞PageNo,PageSize,OrderBy等分頁信息,。而服務端將向EC返回總記錄數(shù)和當前頁的內(nèi)容。

2.創(chuàng)建Limit

首先你需要通過LimitFactory得到一個Limit實例:


代碼
  1. Context context = new HttpServletRequestContext(request);   
  2.       LimitFactory limitFactory = new TableLimitFactory(context);   
  3.       Limit limit = new TableLimit(limitFactory);   

Limit對象定義了limit結(jié)果集的所有方法,。
TableLimitFactory具有另外一個構(gòu)造函數(shù),,如果JSP頁面使用了兩個(以上)eXtremeTable的話你可以利用tableId分別傳輸totalRows,如果默認tableId將為所有ec,。

 

 

Context context = new HttpServletRequestContext(request);
LimitFactory limitFactory = new TableLimitFactory(context, tableId);
Limit limit = new TableLimit(limitFactory);
設置行屬性:

limit.setRowAttributes(totalRows, DEFAULT_ROWS_DISPLAYED);

3. 前臺jsp頁面中ec標薟寫法:


代碼
  1. <ec:table  
  2.         items="userlist"  
  3.         var="u"  
  4.         action="/pageAction.do"          
  5.         title="后臺用戶管理——管理用戶"  
  6.         retrieveRowsCallback="limit"    
  7.         width="80%"  
  8.         rowsDisplayed="3"  
  9.         form=""  
  10.         >      
  11.         <ec:row>  
  12.             ...   
  13.             ...              
  14.         </ec:row>  
  15.     </ec:table>  

使用callback需要做的唯一事情是傳輸集合到request,,同時傳輸totalRows屬性,。 totalRows表示總行數(shù),,

 

代碼
  1. request.setAttribute("userlist", userlist);   
  2.        request.setAttribute("totalRows"new Integer(總記錄數(shù)));  

 

 

4.實例:
本實例是ec結(jié)合Struts和Hibernate進行分頁.

PageAction中的部分代碼:

代碼
  1. public ActionForward execute(ActionMapping mapping, ActionForm form,   
  2.   HttpServletRequest request, HttpServletResponse response)   
  3.         throws Exception {   
  4.      UserDAO userDAO = (UserDAO) getBean("userDAO");    
  5.      Limit limit = ExtremeTablePage.getLimit(request,defaultPageSize);   
  6.      PageBean page = new PageBean();   
  7.      page.setPageSize(limit.getCurrentRowsDisplayed()); //ec通過limit對象傳遞pageSize給PageBean   
  8.      page.setPage(limit.getPage());//ec通過limit對象傳遞pageNo給PageBean   
  9.      List list = userDAO.findAllUser(page);   
  10.      request.setAttribute("userlist", list);   
  11.      request.setAttribute("totalRows"new Integer(page.getCount()));   
  12.        
  13.      return mapping.findForward("userlist");   
  14.      
  15.  }   

Limit對象的實例化在ExtremeTablePage中

 

代碼
  1. static public Limit getLimit(HttpServletRequest request,int defaultPageSize) {   
  2.    Context context = new HttpServletRequestContext(request);   
  3.    LimitFactory limitFactory = new TableLimitFactory(context);   
  4.    TableLimit limit = new TableLimit(limitFactory);   
  5.    limit.setRowAttributes(Integer.MAX_VALUE, defaultPageSize);   
  6.    return limit;   
  7.  }   


PageBean類部分代碼:

 

代碼
  1. public class PageBean {   
  2.       private int count = 0// 記錄總數(shù)   
  3.       private int pageSize = 10// 每頁顯示記錄數(shù)   
  4.           private int pageCount = 0// 總頁數(shù)   
  5.           private int page = 1// 當前頁數(shù)   
  6.           .   
  7.           .   
  8.           .   
  9.           public int getCount() {   
  10.              return count;   
  11.          }   
  12.        public void setCount(int count) {   
  13.           if (pageSize != 0) {   
  14.              pageCount = count / pageSize;   
  15.           if (count % pageSize != 0) {   
  16.              pageCount++;   
  17.            }   
  18.        }   
  19.        this.count = count;   
  20.       }   
  21.     
  22.       public int getPage() {   
  23.         return page;   
  24.       }   
  25.      public void setPage(int page) {   
  26.        this.page = page;   
  27.      }   
  28.      public int getPageCount() {   
  29.       return pageCount;   
  30.      }   
  31.      public void setPageCount(int pageCount) {   
  32.        this.pageCount = pageCount;   
  33.     }   
  34.      public int getPageSize() {   
  35.        return pageSize;   
  36.      }   
  37.      public void setPageSize(int pageSize) {   
  38.        this.pageSize = pageSize;   
  39.      }   
  40.   .   
  41.   .   
  42.   .   
  43.  }  
dao層使用PageBean對象進行查詢,。
 

    本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內(nèi)容均由用戶發(fā)布,,不代表本站觀點,。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,,謹防詐騙,。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報,。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多