elementUI實現分頁
分頁的兩種方式。前端分頁,後端分頁
- 前端分頁:後臺只需將資料返回,不需要做過多處理,前端一次請求拿到所有資料後做分頁處理。但資料量不能太大,因為前端是先一次性載入所有資料,然後在做分頁處理。在資料量多的情況下,載入相對應的會變慢。所有在前端做分頁時要先考慮一下後期的資料量。
- 後端分頁:因為是後端分頁,前端在每點選一次分頁時,便向後臺請求一次資料。其實就是避免前端一次性從資料庫獲取大量資料
一、在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: '上海市普陀區金沙江路 1518 弄'
}, {
date: '2016-05-04',
name: '王小虎',
address: '上海市普陀區金沙江路 1517 弄'
}, {
date: '2016-05-01',
name: '王小虎',
address: '上海市普陀區金沙江路 1519 弄'
}, {
date: '2016-05-03',
name: '王小虎',
address: '上海市普陀區金沙江路 1516 弄'
}],
// 預設顯示第一條
currentPage:1
}
},
methods: {
handleSizeChange(val) {
console.log(`每頁 ${val} 條`);
},
handleCurrentChange(val) {
console.log(`當前頁: ${val}`);
}
},
}
</script>
二、分頁部分
- 前端分頁
<template>
<div class="app">
<!-- 將獲取到的資料進行計算 -->
<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 {
// 總資料
tableData:[],
// 預設顯示第幾頁
currentPage:1,
// 總條數,根據介面獲取資料長度(注意:這裡不能為空)
totalCount:1,
// 個數選擇器(可修改)
pageSizes:[1,2,3,4],
// 預設每頁顯示的條數(可修改)
PageSize:1,
}
},
methods:{
getData(){
// 這裡使用axios,使用時請提前引入
axios.post(url,{
orgCode:1
},{emulateJSON: true},
{
headers:{"Content-Type": "application/x-www-form-urlencoded;charset=utf-8",}
}
).then(reponse=>{
console.log(reponse)
// 將資料賦值給tableData
this.tableData=data.data.body
// 將資料的長度賦值給totalCount
this.totalCount=data.data.body.length
})
},
// 分頁
// 每頁顯示的條數
handleSizeChange(val) {
// 改變每頁顯示的條數
this.PageSize=val
// 注意:在改變每頁顯示的條數時,要將頁碼顯示到第一頁
this.currentPage=1
},
// 顯示第幾頁
handleCurrentChange(val) {
// 改變預設的頁數
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 {
// 總資料
tableData:[],
// 預設顯示第幾頁
currentPage:1,
// 總條數,根據介面獲取資料長度(注意:這裡不能為空)
totalCount:1,
// 個數選擇器(可修改)
pageSizes:[1,2,3,4],
// 預設每頁顯示的條數(可修改)
PageSize:1,
}
},
methods:{
// 將頁碼,及每頁顯示的條數以引數傳遞提交給後臺
getData(n1,n2){
// 這裡使用axios,使用時請提前引入
axios.post(url,{
orgCode:1,
// 每頁顯示的條數
PageSize:n1,
// 顯示第幾頁
currentPage:n2,
},{emulateJSON: true},
{
headers:{"Content-Type": "application/x-www-form-urlencoded;charset=utf-8",}
}
).then(reponse=>{
console.log(reponse)
// 將資料賦值給tableData
this.tableData=data.data.body
// 將資料的長度賦值給totalCount
this.totalCount=data.data.body.length
})
},
// 分頁
// 每頁顯示的條數
handleSizeChange(val) {
// 改變每頁顯示的條數
this.PageSize=val
// 點選每頁顯示的條數時,顯示第一頁
this.getData(val,1)
// 注意:在改變每頁顯示的條數時,要將頁碼顯示到第一頁
this.currentPage=1
},
// 顯示第幾頁
handleCurrentChange(val) {
// 改變預設的頁數
this.currentPage=val
// 切換頁碼時,要獲取每頁顯示的條數
this.getData(this.PageSize,(val)*(this.pageSize))
},
},
created:function(){
this.getData(this.PageSize,this.currentPage)
}
}
</script>
相關文章
- SpringBoot+MP+ElementUI【分頁】Spring BootUI
- 分頁功能的實現
- web 實現分頁列印功能Web
- Java實現後端分頁Java後端
- MyBatis實現分頁的方式MyBatis
- 使用 jQuery 實現分頁功能jQuery
- PHP 使用 Redis 實現分頁PHPRedis
- 47.DRF實現分頁
- indexdb實現分頁查詢Index
- 使用LayUI實現AJAX分頁UI
- Django 前端BootCSS 實現分頁Django前端bootCSS
- 分頁實現前臺後臺不同效果,分頁類引入
- 分頁實現前五後五ajax區域性重新整理方式分頁實現
- uni-app之實現分頁APP
- SpringBoot 整合Mybatis + PageHelper 實現分頁Spring BootMyBatis
- 用AutoLayout實現分頁滾動
- 文章內容分頁功能實現
- Python | 實現pdf檔案分頁Python
- SpringMVC+Spring Data JPA +Bootstrap 分頁實現和模糊查詢分頁SpringMVCboot
- 【MyBatis框架】MyBatis實現物理分頁和邏輯(記憶體)分頁MyBatis框架記憶體
- vue+Element-ui實現分頁效果VueUI
- SSM框架實現分頁查詢例子SSM框架
- django 網站實現簡單分頁Django網站
- Mybatis 分頁:Pagehelper + 攔截器實現MyBatis
- 教你如何使用MvcPager實現分頁效果MVC
- c# winform 實現分頁查詢C#ORM
- 如何優雅地實現分頁查詢
- kPagination-純js實現分頁外掛JS
- DjangoRestFramework 實現分頁功能與搜尋功能DjangoRESTFramework
- iOS 類知乎”分頁”效果的實現?iOS
- python實現資料分頁小練習Python
- jQuery入門(六)jQuery實現瀑布分頁jQuery
- 如何實現一個mybaits 分頁外掛AI
- php原聲實現分頁程式碼示例PHP
- 使用延遲關聯實現高效分頁
- asyUI分頁中,如何實現頁面跳轉,再返回時,...UI
- php 分頁 分頁類 簡單實用PHP
- SSH整合實現分頁查詢(兩種方式)