分頁的兩種方式方庭。前端分頁厕吉,后端分頁。兩種方式各有個的優(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⒘丁!