elementUI實現(xiàn)分頁

分頁的兩種方式方庭。前端分頁厕吉,后端分頁。兩種方式各有個的優(yōu)缺點吧械念。

  • 前端分頁:后臺只需將數(shù)據(jù)返回头朱,不需要做過多處理,前端一次請求拿到所有數(shù)據(jù)后做分頁處理龄减。但數(shù)據(jù)量不能太大项钮,因為前端是先一次性加載所有數(shù)據(jù),然后在做分頁處理希停。在數(shù)據(jù)量多的情況下烁巫,加載相對應的會變慢。所有在前端做分頁時要先考慮一下后期的數(shù)據(jù)量宠能。
  • 后端分頁:因為是后端分頁亚隙,前端在每點擊一次分頁時,便向后臺請求一次數(shù)據(jù)违崇。其實就是避免前端一次性從數(shù)據(jù)庫獲取大量數(shù)據(jù)

一阿弃、在elementUI中將表格、分頁引入自己的頁面中

  <template>
  <div class="app">
      <el-table :data="tableData" style="width: 100%">
          <el-table-column prop="date" label="日期" width="180"></el-table-column>
          <el-table-column prop="name" label="姓名" width="180"></el-table-column>
          <el-table-column prop="address" label="地址"></el-table-column>
      </el-table>
      <el-pagination
        @size-change="handleSizeChange"
        @current-change="handleCurrentChange"
        :current-page="currentPage"
        :page-sizes="[100, 200, 300, 400]"
        :page-size="100"
        layout="total, sizes, prev, pager, next, jumper"
        :total="400">
      </el-pagination>
  </div>
  </template>
  <script>
    export default {
      data() {
        return {
          tableData: [{
            date: '2016-05-02',
            name: '王小虎',
            address: '上海市普陀區(qū)金沙江路 1518 弄'
          }, {
            date: '2016-05-04',
            name: '王小虎',
            address: '上海市普陀區(qū)金沙江路 1517 弄'
          }, {
            date: '2016-05-01',
            name: '王小虎',
            address: '上海市普陀區(qū)金沙江路 1519 弄'
          }, {
            date: '2016-05-03',
            name: '王小虎',
            address: '上海市普陀區(qū)金沙江路 1516 弄'
          }],
          // 默認顯示第一條
          currentPage:1
        }
      },
      methods: {
          handleSizeChange(val) {
            console.log(`每頁 ${val} 條`);
          },
          handleCurrentChange(val) {
            console.log(`當前頁: ${val}`);
          }
       },
    }
  </script>

實現(xiàn)一個簡單表格羞延,在做分頁時渣淳,數(shù)據(jù)盡可能在10-20條,方便演示
二伴箩、分頁部分(分頁分前端分頁與后端分頁)

  • 前端分頁(在一的基礎上添加分頁功能)
<template>
 <div class="app">    
     <!-- 將獲取到的數(shù)據(jù)進行計算 -->   
     <el-table :data="tableData.slice((currentPage-1)*PageSize,currentPage*PageSize)" style="width: 100%">
         <el-table-column prop="date" label="日期" width="180"></el-table-column>
         <el-table-column prop="name" label="姓名" width="180"></el-table-column>
         <el-table-column prop="address" label="地址"></el-table-column>
     </el-table>
      <div class="tabListPage">
           <el-pagination @size-change="handleSizeChange" 
                          @current-change="handleCurrentChange" 
                          :current-page="currentPage" 
                          :page-sizes="pageSizes" 
                          :page-size="PageSize" layout="total, sizes, prev, pager, next, jumper" 
                          :total="totalCount">
             </el-pagination>
       </div>
</div>
</template>
<script>
export default {
   data(){
       return {
            // 總數(shù)據(jù)
           tableData:[],
           // 默認顯示第幾頁
           currentPage:1,
           // 總條數(shù)入愧,根據(jù)接口獲取數(shù)據(jù)長度(注意:這里不能為空)
           totalCount:1,
           // 個數(shù)選擇器(可修改)
           pageSizes:[1,2,3,4],
           // 默認每頁顯示的條數(shù)(可修改)
           PageSize:1,
       }
   },
 methods:{
       getData(){
             // 這里使用axios,使用時請?zhí)崆耙?             axios.post(url,{
                  orgCode:1
             },{emulateJSON: true},
             {
               headers:{"Content-Type": "application/x-www-form-urlencoded;charset=utf-8",} 
              }
              ).then(reponse=>{
                   console.log(reponse)
                   // 將數(shù)據(jù)賦值給tableData
                   this.tableData=data.data.body
                   // 將數(shù)據(jù)的長度賦值給totalCount
                   this.totalCount=data.data.body.length
              }) 
         },
       // 分頁
        // 每頁顯示的條數(shù)
       handleSizeChange(val) {
           // 改變每頁顯示的條數(shù) 
           this.PageSize=val
           // 注意:在改變每頁顯示的條數(shù)時嗤谚,要將頁碼顯示到第一頁
           this.currentPage=1
       },
         // 顯示第幾頁
       handleCurrentChange(val) {
           // 改變默認的頁數(shù)
           this.currentPage=val
       },
   },
   created:function(){
         this.getData() 
   }
}
</script>
  • 后端分頁(在一的基礎上添加分頁功能)
<template>
  <div class="app">  
      <el-table :data="tableData" style="width: 100%">
          <el-table-column prop="date" label="日期" width="180"></el-table-column>
          <el-table-column prop="name" label="姓名" width="180"></el-table-column>
          <el-table-column prop="address" label="地址"></el-table-column>
      </el-table>
       <div class="tabListPage">
            <el-pagination @size-change="handleSizeChange" 
                           @current-change="handleCurrentChange" 
                           :current-page="currentPage" 
                           :page-sizes="pageSizes" 
                           :page-size="PageSize" layout="total, sizes, prev, pager, next, jumper" 
                           :total="totalCount">
              </el-pagination>
        </div>
 </div>
</template>
<script>
export default {
    data(){
        return {
             // 總數(shù)據(jù)
            tableData:[],
            // 默認顯示第幾頁
            currentPage:1,
            // 總條數(shù)棺蛛,根據(jù)接口獲取數(shù)據(jù)長度(注意:這里不能為空)
            totalCount:1,
            // 個數(shù)選擇器(可修改)
            pageSizes:[1,2,3,4],
            // 默認每頁顯示的條數(shù)(可修改)
            PageSize:1,
        }
    },
  methods:{
         // 將頁碼,及每頁顯示的條數(shù)以參數(shù)傳遞提交給后臺
        getData(n1,n2){
              // 這里使用axios呵恢,使用時請?zhí)崆耙?              axios.post(url,{
                   orgCode:1,
                   // 每頁顯示的條數(shù)
                   PageSize:n1,
                   // 顯示第幾頁
                   currentPage:n2,
              },{emulateJSON: true},
              {
                headers:{"Content-Type": "application/x-www-form-urlencoded;charset=utf-8",} 
               }
               ).then(reponse=>{
                    console.log(reponse)
                    // 將數(shù)據(jù)賦值給tableData
                    this.tableData=data.data.body
                    // 將數(shù)據(jù)的長度賦值給totalCount
                    this.totalCount=data.data.body.length
               }) 
          },
        // 分頁
         // 每頁顯示的條數(shù)
        handleSizeChange(val) {
            // 改變每頁顯示的條數(shù) 
            this.PageSize=val
            // 點擊每頁顯示的條數(shù)時鞠值,顯示第一頁
            this.getData(val,1)
            // 注意:在改變每頁顯示的條數(shù)時,要將頁碼顯示到第一頁
            this.currentPage=1  
        },
          // 顯示第幾頁
        handleCurrentChange(val) {
            // 改變默認的頁數(shù)
            this.currentPage=val
            // 切換頁碼時渗钉,要獲取每頁顯示的條數(shù)
            this.getData(this.PageSize,(val)*(this.pageSize))
        },
    },
    created:function(){
          this.getData(this.PageSize,this.currentPage) 
    }
 }
</script>

注:后臺分頁等待驗證
問題

  • 當前端分頁時彤恶,頁面上的彈框會將已經(jīng)勾選的數(shù)據(jù)清空钞钙,拿不到已被勾選的數(shù)據(jù)。這個問題還需要解決声离,希望各位大神的幫助C⒘丁!
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末术徊,一起剝皮案震驚了整個濱河市本刽,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌赠涮,老刑警劉巖子寓,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異笋除,居然都是意外死亡斜友,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進店門垃它,熙熙樓的掌柜王于貴愁眉苦臉地迎上來鲜屏,“玉大人,你說我怎么就攤上這事国拇÷迨罚” “怎么了?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵酱吝,是天一觀的道長也殖。 經(jīng)常有香客問我,道長掉瞳,這世上最難降的妖魔是什么毕源? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任浪漠,我火速辦了婚禮陕习,結果婚禮上,老公的妹妹穿的比我還像新娘址愿。我一直安慰自己该镣,他們只是感情好,可當我...
    茶點故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布响谓。 她就那樣靜靜地躺著损合,像睡著了一般。 火紅的嫁衣襯著肌膚如雪娘纷。 梳的紋絲不亂的頭發(fā)上嫁审,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天,我揣著相機與錄音赖晶,去河邊找鬼律适。 笑死辐烂,一個胖子當著我的面吹牛,可吹牛的內容都是我干的捂贿。 我是一名探鬼主播纠修,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼厂僧!你這毒婦竟也來了扣草?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤颜屠,失蹤者是張志新(化名)和其女友劉穎辰妙,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體甫窟,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡上岗,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了蕴坪。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片肴掷。...
    茶點故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖背传,靈堂內的尸體忽然破棺而出呆瞻,到底是詐尸還是另有隱情,我是刑警寧澤径玖,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布痴脾,位于F島的核電站,受9級特大地震影響梳星,放射性物質發(fā)生泄漏赞赖。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一冤灾、第九天 我趴在偏房一處隱蔽的房頂上張望前域。 院中可真熱鬧,春花似錦韵吨、人聲如沸匿垄。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽椿疗。三九已至,卻和暖如春糠悼,著一層夾襖步出監(jiān)牢的瞬間届榄,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工倔喂, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留铝条,地道東北人童擎。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像攻晒,于是被迫代替她去往敵國和親顾复。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,901評論 2 345

推薦閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,522評論 25 707
  • 一直以為鲁捏,幸福就好比那夜空中的銀河芯砸,可望而不可及。時常感嘆自己離幸福很遙遠给梅,卻不知假丧,幸福其實很簡單,只要一伸手动羽,便...
    執(zhí)筆溢情閱讀 479評論 0 0
  • 我的理財觀很簡單包帚,有兩條:1、錢是用來花的运吓,不是用來攢的渴邦;2、花明天的錢辦今天的事拘哨。 大學期間...
    矮窮但有才閱讀 164評論 0 0
  • 拍攝地:大連軟件園 拍攝器材:蘋果SE 出春谋梭,偶遇蝴蝶。 在丁香花開的季節(jié)倦青,有你瓮床,有我,芬芳滿園…… 圖片版權歸本...
    一人一葉閱讀 302評論 2 1