最終效果展
<div class="deit">
<div class="crumbs">
<el-breadcrumb separator="/">
<el-breadcrumb-item><i class="el-icon-date"></i> 數據管理</el-breadcrumb-item>
<el-breadcrumb-item>用戶列表</el-breadcrumb-item>
</el-breadcrumb>
<div class="cantainer">
<el-table style="width: 100%;"
:data="allList.slice((currentPage-1)*pagesize,currentPage*pagesize)" //對數據請求的處理,最為重要的一句話
>
<el-table-column type="index" width="50">
</el-table-column>
<el-table-column label="日期" prop="date" width="180">
</el-table-column>
<el-table-column label="用戶姓名" prop="name" width="180">
</el-table-column>
<el-table-column label="郵箱" prop="email" width="180">
</el-table-column>
<el-table-column label="地址" prop="address" width="200">
</el-table-column>
</el-table>
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="currentPage"
:page-sizes="[5, 10, 20, 40]" //這是下拉框可以選擇的,每選擇一行,要展示多少內容
:page-size="pagesize" //顯示當前行的條數
layout="total, sizes, prev, pager, next, jumper"
:total="userList.length"> //這是顯示總共有多少數據,
</el-pagination>
</div>
</div>
</div>
需要data定義一些,userList定義一個空數組,請求的數據都是存放這里面
data () {
return {
currentPage:1, //初始頁
pagesize:10, // 每頁的數據
allList: []
}
},
對一些數據,方法處理,數據的來源是自己通過json-server搭建的本地數據,通過vue-resource請求數據,
created() {
this.handleallList()
},
methods: {
// 初始頁currentPage、初始每頁數據數pagesize和數據data
handleSizeChange: function (size) {
this.pagesize = size;
console.log(this.pagesize) //每頁下拉顯示數據
},
handleCurrentChange: function(currentPage){
this.currentPage = currentPage;
console.log(this.currentPage) //點擊第幾頁
},
handleUserList() {
this.$http.get('http://localhost:3000/userList').then(res => { //這是從本地請求的數據接口,
this.allList = res.body
})
}
}
