欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue使用elementUI組件實現(xiàn)分頁效果

 更新時間:2023年12月18日 11:35:43   作者:isxxya  
分頁在展示數(shù)據(jù)列表的場景肯定是非常多的,一般的項目開發(fā)中,數(shù)據(jù)量特別大,一般都是后端接口直接處理分頁返回,前端直接調(diào)用即可,本文給大家介紹了vue使用elementUI組件實現(xiàn)分頁效果,需要的朋友可以參考下

分頁的兩種方式。前端分頁,后端分頁

前端分頁:后臺只需將數(shù)據(jù)返回,不需要做過多處理,前端一次請求拿到所有數(shù)據(jù)后做分頁處理。但數(shù)據(jù)量不能太大,因為前端是先一次性加載所有數(shù)據(jù),然后在做分頁處理。在數(shù)據(jù)量多的情況下,加載相對應(yīng)的會變慢。所有在前端做分頁時要先考慮一下后期的數(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 弄'
          }],
          // 默認(rèn)顯示第一條
          currentPage:1
        }
      },
      methods: {
          handleSizeChange(val) {
            console.log(`每頁 ${val} 條`);
          },
          handleCurrentChange(val) {
            console.log(`當(dāng)前頁: ${val}`);
          }
       },
    }
  </script>

二、分頁部分

  • 前端分頁
<template>
 <div class="app">    
     <!-- 將獲取到的數(shù)據(jù)進(jìn)行計算 -->   
     <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:[],
           // 默認(rèn)顯示第幾頁
           currentPage:1,
           // 總條數(shù),根據(jù)接口獲取數(shù)據(jù)長度(注意:這里不能為空)
           totalCount:1,
           // 個數(shù)選擇器(可修改)
           pageSizes:[1,2,3,4],
           // 默認(rèn)每頁顯示的條數(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) {
           // 改變默認(rèn)的頁數(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:[],
            // 默認(rèn)顯示第幾頁
            currentPage:1,
            // 總條數(shù),根據(jù)接口獲取數(shù)據(jù)長度(注意:這里不能為空)
            totalCount:1,
            // 個數(shù)選擇器(可修改)
            pageSizes:[1,2,3,4],
            // 默認(rèn)每頁顯示的條數(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) {
            // 改變默認(rèn)的頁數(shù)
            this.currentPage=val
            // 切換頁碼時,要獲取每頁顯示的條數(shù)
            this.getData(this.PageSize,(val)*(this.pageSize))
        },
    },
    created:function(){
          this.getData(this.PageSize,this.currentPage) 
    }
 }
</script>

到此這篇關(guān)于vue使用elementUI組件實現(xiàn)分頁效果的文章就介紹到這了,更多相關(guān)vue elementUI分頁內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue組件打包并發(fā)布到npm的全過程

    vue組件打包并發(fā)布到npm的全過程

    這篇文章主要介紹了vue組件打包并發(fā)布到npm的全過程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue3.2?新增指令?v-memo?用法詳解(提高性能利器)

    Vue3.2?新增指令?v-memo?用法詳解(提高性能利器)

    v-memo 接受一個依賴的數(shù)組,依賴的數(shù)組變化,v-memo 所對應(yīng)的 DOM 包括子集將會重新渲染,這篇文章主要介紹了Vue3.2?新增指令?v-memo?用法,提高性能的又一利器,需要的朋友可以參考下
    2022-09-09
  • 詳解Electron中如何使用SQLite存儲筆記

    詳解Electron中如何使用SQLite存儲筆記

    這篇文章主要為大家介紹了Electron中如何使用SQLite存儲筆記示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • ant design vue中日期選擇框混合時間選擇器的用法說明

    ant design vue中日期選擇框混合時間選擇器的用法說明

    這篇文章主要介紹了ant design vue中日期選擇框混合時間選擇器的用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • vue組件實現(xiàn)移動端九宮格轉(zhuǎn)盤抽獎

    vue組件實現(xiàn)移動端九宮格轉(zhuǎn)盤抽獎

    這篇文章主要為大家詳細(xì)介紹了vue組件實現(xiàn)移動端九宮格轉(zhuǎn)盤抽獎,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • Vue中Pinia的各種詳細(xì)說明和使用示例

    Vue中Pinia的各種詳細(xì)說明和使用示例

    Pinia是Vue 3的專屬狀態(tài)管理庫,旨在替代Vuex,提供更簡單、直觀的狀態(tài)管理解決方案,它支持組合式API和選項式API,允許跨組件或頁面共享狀態(tài),避免了Vuex中的許多復(fù)雜概念,本文介紹Vue中Pinia的各種詳細(xì)說明和使用示例,感興趣的朋友一起看看吧
    2025-01-01
  • vue界面發(fā)送表情的實現(xiàn)代碼

    vue界面發(fā)送表情的實現(xiàn)代碼

    這篇文章主要介紹了vue界面發(fā)送表情的實現(xiàn)代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • vue實現(xiàn)列表拖拽排序的功能

    vue實現(xiàn)列表拖拽排序的功能

    這篇文章主要介紹了vue實現(xiàn)列表拖拽排序的功能,幫助大家更好的理解和學(xué)習(xí)vue,感興趣的朋友可以了解下
    2020-11-11
  • vue.js頁面加載執(zhí)行created,mounted的先后順序說明

    vue.js頁面加載執(zhí)行created,mounted的先后順序說明

    這篇文章主要介紹了vue.js頁面加載執(zhí)行created,mounted的先后順序說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Vue3中使用監(jiān)聽器的具體實踐

    Vue3中使用監(jiān)聽器的具體實踐

    監(jiān)聽器是Vue3中非常好用的一個特性,用于監(jiān)聽某個響應(yīng)式變量的變化,本文就來介紹一下Vue3中使用監(jiān)聽器的具體實踐,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12

最新評論