日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

用jsp進(jìn)行數(shù)據(jù)分頁顯示的一個(gè)實(shí)現(xiàn)

系統(tǒng) 1828 0
互聯(lián)網(wǎng)時(shí)代實(shí)際上是數(shù)據(jù)的時(shí)代,構(gòu)建大型電子商務(wù)系統(tǒng)必然要涉及到大量數(shù)據(jù)顯示,數(shù)據(jù)的分頁顯示是頻繁遇到的問題,如果讓每個(gè)程序員都要考慮數(shù)據(jù)的獲取與處理的每個(gè)細(xì)節(jié),那必將是件既糟糕又混亂的事情,類似于分頁顯示這種具有公共特征的控制邏輯必定要在horizonal layer層予以實(shí)現(xiàn)

本文以循序漸進(jìn)的方式給出了用jsp處理分頁顯示的一個(gè)可重用,易于移植的實(shí)現(xiàn)。

如果把與各種商業(yè)邏輯實(shí)體相對(duì)應(yīng)的數(shù)據(jù)叫做"實(shí)體數(shù)據(jù)",那么分頁顯示邏輯要封裝的就是控制實(shí)體數(shù)據(jù)的"控制數(shù)據(jù)"(下文中沿用這兩種說法).

首先讓我們構(gòu)建一個(gè)PageControl對(duì)象將分頁所涉及到的一些關(guān)鍵的"控制數(shù)據(jù)"予以封裝.

具體說明如下:

  1. public int curPage ; //當(dāng)前是第幾頁
  2. public int maxPage ; //一共有多少頁
  3. public int maxRowCount ; //一共有多少行
  4. public int rowsPerPage ; //每頁有多少行
  5. public yourDataType yourdata ;//裝載每頁的數(shù)據(jù)
    關(guān)于每頁所要顯示的"實(shí)體數(shù)據(jù)"的載體,其實(shí)現(xiàn)方式多種多樣,比如說在IBM電子商務(wù)系統(tǒng)MPE中是以bean的形式,這是一種面向?qū)ο蟮膶?shí)現(xiàn),比較的簡略的實(shí)現(xiàn)可用java.util.Vector等,為了避免分散對(duì)核心問題的的注意力,這里用youDataType予以抽象.

  6.                 
                      public void countMaxPage() {   //根據(jù)總行數(shù)計(jì)算總頁數(shù)  
        if (this.maxRowCount % this.rowsPerPage==0){
           this.maxPage = this.maxRowCount/this.rowsPerPage;
        }else{
           this.maxPage = this.maxRowCount/this.rowsPerPage + 1;        
            }
        }
                    
                  
    this.rowsPerPage其實(shí)應(yīng)從配置文件中獲得,這樣做的好處是程序能在運(yùn)行中讀取從而實(shí)現(xiàn)動(dòng)態(tài)(再)配置,簡略的做法是直接寫在程序中。
  7. public PageControl(yourPersistenceLayer yourPL)
    這是一個(gè)參數(shù)類型為yourPersistenceLayer的構(gòu)造函數(shù).PersistenceLayer是直接同數(shù)據(jù)庫打交道的一層,不同的公司都有不同的實(shí)現(xiàn),比如說Microsoft的ADO就可以看作是一PersistenceLayer,IBM在其MPE系統(tǒng)中也實(shí)現(xiàn)了一個(gè)龐大的PersistenceLayer,. 一種投機(jī)的做法是不要PersistenceLayer,或者可以說是淡化該層,這樣做勢必降低系統(tǒng)的穩(wěn)定性,可重用性,可擴(kuò)展性。具體可以參考附錄文獻(xiàn).在這個(gè)構(gòu)造函數(shù)中,有這樣幾個(gè)主要操作:
                    
                         this.maxRowCount = yourPL.getAvailableCount();  //得到總行數(shù)
        this.yourdata    = yourPL.getResult();          //得到要顯示于本頁的數(shù)據(jù)
        this.countMaxPage();                         //計(jì)算總頁數(shù)
    
                    
                  


關(guān)于this.yourdata這里還有一個(gè)細(xì)節(jié):在從數(shù)據(jù)庫中獲取"實(shí)體數(shù)據(jù)"時(shí),通常有兩種方式:(A)一次性獲取所有數(shù)據(jù);(B)每次根據(jù)當(dāng)前頁號(hào),獲取本頁的數(shù)據(jù),將其它數(shù)據(jù)予以拋棄;考慮到數(shù)據(jù)往往是大量甚至是海量的,如果一次性的獲取,那么這些數(shù)據(jù)必然大量占用服務(wù)器內(nèi)存資源,使系統(tǒng)性能大大降低,因此建議使用方法(A)

接下來的工作就可以交給servlet和jsp了
在servlet的service()方法中只需進(jìn)行如下操作:

            
              PageControl  pageCtl = yourBusinessObject.listData(req.getParameter("jumpPage"));
req.setAttribute("pageCtl",pageCtl);

            
          
說明:yourBusinessObject封裝了商業(yè)邏輯,是位于Business Logic Layer中的一個(gè)對(duì)象,運(yùn)用OOAD的方法,封裝商業(yè)對(duì)象,在Persistent Layer之上組建堅(jiān)實(shí)的Business Logic Layer同樣是構(gòu)建大型電子商務(wù)架構(gòu)的關(guān)鍵所在。本文的關(guān)注點(diǎn)只是分頁處理,暫不詳細(xì)論述.

在每個(gè)想要實(shí)現(xiàn)翻頁顯示數(shù)據(jù)的jsp頁面中, 我們的工作也很簡單,其代碼是公式化的:

            
              <?xml:namespace prefix = jsp /><usebean class="yourpackage.PageControl" id="pageCtl" scope="request"></usebean>
 




            
          
  1. 說明:
  2. if(pageCtl.maxPage!=1)實(shí)現(xiàn)了這樣一個(gè)邏輯:如果所取得數(shù)據(jù)不足一頁,那么就不用進(jìn)行翻頁顯示。
  3. 我們注意到這使得真正的翻頁部分完全得到了重用.


那么pageman.jsp到底做了些什么呢? 它實(shí)現(xiàn)了經(jīng)常做翻頁處理的人耳熟能詳?shù)倪壿?
(A)第一頁時(shí)不能再向前翻;
(B)最后一頁時(shí)不能再向后翻;
同時(shí)能夠進(jìn)行頁面任意跳轉(zhuǎn),具體代碼如下:

            
              每頁行
共行
第頁
共頁

              
首頁 上一頁 下一頁 尾頁 轉(zhuǎn)到第> >頁
在頁面上會(huì)呈現(xiàn)出形如下圖的外觀,至于想要修飾美化,那是美工的工作所在。

最后附上用于頁面跳轉(zhuǎn)的javascript公共函數(shù):

            
              function Jumping(){
  document.PageForm.submit();
  return ;
}

function gotoPage(pagenum){
  document.PageForm.jumpPage.value = pagenum;
  document.PageForm.submit();
  return ;
}

            
          


如果他們位于名為TurnPage.js的文件中,那么在每個(gè)要實(shí)現(xiàn)翻頁數(shù)據(jù)顯示的jsp頁面中加上這樣的引用:
<script language="JavaScript" src="/yourPath/TurnPage.js"></script>

用jsp進(jìn)行數(shù)據(jù)分頁顯示的一個(gè)實(shí)現(xiàn)


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦!??!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 郑州市| 缙云县| 大方县| 广汉市| 大兴区| 宁乡县| 岑巩县| 华池县| 定南县| 合肥市| 和田县| 洪湖市| 新巴尔虎左旗| 余庆县| 福建省| 石阡县| 区。| 东宁县| 龙山县| 丁青县| 花莲市| 乌兰浩特市| 通渭县| 河东区| 体育| 靖江市| 南雄市| 厦门市| 威海市| 望城县| 峡江县| 霍州市| 铜山县| 伊春市| 明光市| 措美县| 高淳县| 新源县| 双峰县| 达尔| 句容市|