Vue+Element-U實現(xiàn)分頁顯示效果
本文實例為大家分享了Vue+Element-U實現(xiàn)分頁顯示效果的具體代碼,供大家參考,具體內(nèi)容如下
當(dāng)我們從后端返回的數(shù)據(jù)量很大,并且根據(jù)需求我們需要將返回的數(shù)據(jù)全部都顯示在頁面中,默認(rèn)情況下會把所有的數(shù)據(jù)全部顯示在一個頁面,這樣非常影響視覺和頁面的使用,所以需要使用分頁
我這次使用的是Vue4.0 + Element-UI組件,Element-UI庫非常的豐富,它提供了一個分頁組件 Pagination
展示效果:這個是獲取兩個時間段的上機記錄

HTML部分:
<el-card> <div class="block"> <span style="left:-100px; position:relative"> <span class="demonstration" style='margin-right:10px'> 開始日期 </span> <el-date-picker v-model="value1" type="datetime" placeholder="選擇日期" format="yyyy-MM-dd HH:mm:ss" value-format="yyyy-MM-dd hh:mm:ss"> </el-date-picker> </span> <span style="left:-70px; position:relative"> <span class="demonstration" style='margin-right:10px'> 截止日期</span> <el-date-picker v-model="value2" type="datetime" placeholder="選擇日期" value-format="yyyy-MM-dd HH:mm:ss" format="yyyy-MM-dd hh:mm:ss"> </el-date-picker> </span> <el-button type="primary" style="left:-40px;position:relative" @click="lineCrodList"> 搜索 </el-button> </div> <el-table :data="lineData" style="width: 80%;left:60px;top:20px"> <el-table-column prop="onTime" label="上機時間"> </el-table-column> <el-table-column prop="downTime" label="下機時間"> </el-table-column> <el-table-column prop="spendCash" label="花費時間"> </el-table-column> <el-table-column prop="spendCash" label="花費金額"> </el-table-column> </el-table> <el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange" :current-page="currentPage" :page-sizes="[1, 2, 5, 10]" :page-size="pageSize" layout="total, sizes, prev, pager, next, jumper" :total="total"> </el-pagination> </el-card>
分頁控件的代碼如下:
<el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange" :current-page="currentPage" :page-sizes="[1, 2, 5, 10]" :page-size="pageSize" layout="total, sizes, prev, pager, next, jumper" :total="total"> </el-pagination>
解析:
@size-change:這個是一個方法,當(dāng)在頁面改變每頁顯示的條數(shù)時,會觸發(fā)該方法

@current-change:點擊當(dāng)前頁改變的時候會觸發(fā)該方法

:current-page:當(dāng)前頁數(shù)
:page-sizes:個數(shù)選擇器的選項設(shè)置

:page-size:每頁顯示的條數(shù)
:total:總數(shù)據(jù)數(shù)量
JS代碼:
<script>
export default {
data () {
return {
value1: '',
value2: '',
lineData: [],
username: '',
total: 0, //實現(xiàn)動態(tài)綁定
pageSize: 2,
currentPage: 1,
}
},
methods: {
//當(dāng)改變每頁顯示條數(shù)的選擇器時會觸發(fā)的事件
handleSizeChange (size) {
// 每頁顯示的數(shù)量是我們選擇器選中的值size
this.pageSize = size;
console.log(this.pageSize);//每頁下拉顯示數(shù)據(jù)
this.lineCrodList();
},
//當(dāng)改變當(dāng)前頁數(shù)的時候觸發(fā)的事件
handleCurrentChange (currentPage) {
this.currentPage = currentPage;
console.log(this.currentPage);//點擊第幾頁
this.lineCrodList();
},
//獲取用戶上機記錄的信息分頁
async lineCrodList () {
//調(diào)用 獲取total數(shù)據(jù)的方法
this.counttotal();
await this.$http.post('/Line/SelectInfo', {
userName: this.username,
onTime: this.value1,
downTime: this.value2,
spendCash: 0,
start: (this.currentPage-1)* this.pageSize,
pageSize: this.pageSize
}).then(res => {
this.lineData = res.data;
console.log(res.data)
})
},
//獲取用戶總條數(shù)
async counttotal () {
await this.$http.post('/Line/selectTotal', {
userName: this.username,
onTime: this.value1,
downTime: this.value2,
}).then(res => {
this.total = res.data;
})
}
我們前端請求的時候需要給后端發(fā)送start 和 pageSize 這兩個參數(shù) 因為具體的數(shù)據(jù)是后端通過數(shù)據(jù)庫來搜索的
后臺Sql語句,其他層的代碼我就不在這里列出

可以看到 limit i,n
i:表示查詢結(jié)果的索引值
n:為查詢結(jié)果的返回數(shù)量
i 和 n之間用逗號分隔
例子:
#分頁顯示新聞數(shù)據(jù),每頁顯示兩條,這里顯示第一頁 SELECT id,title,author,createdate FROM news_detail LIMIT 0,2 #分頁顯示新聞數(shù)據(jù),每頁顯示兩條,這里顯示第二頁 SELECT id,title,author,createdate FROM news_detail LIMIT 2,2 #分頁顯示新聞數(shù)據(jù),每頁顯示兩條,這里顯示第三頁 SELECT id,title,author,createdate FROM news_detail LIMIT 4,2 #公用的分頁sql #第二個數(shù):分頁后每頁顯示幾條新聞(頁面容量) pageSize #第一個數(shù):從第幾條數(shù)據(jù)開始顯示(當(dāng)前頁碼pageNo-1)*pageSize SELECT id,title,author,createdate FROM news_detail LIMIT (pageNo-1)*pageSize,pageSize
我把(pageNo-1)*pageSize 寫到了前端,所以就無需在后端重復(fù)寫

# 查詢8條數(shù)據(jù),索引從5到12,第6條記錄到第13條記錄 select * from t_user limit 5,8;
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue項目中輪詢狀態(tài)更改方式(鉤子函數(shù))
這篇文章主要介紹了vue項目中輪詢狀態(tài)更改方式(鉤子函數(shù)),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
vue init webpack myproject構(gòu)建項目 ip不能訪問的解決方法
下面小編就為大家分享一篇vue init webpack myproject構(gòu)建項目 ip不能訪問的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03
vue如何使用el-table遍歷循環(huán)表頭和表體數(shù)據(jù)
這篇文章主要介紹了vue如何使用el-table遍歷循環(huán)表頭和表體數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04
詳解Vue.js搭建路由報錯 router.map is not a function
這篇文章主要介紹了詳解Vue.js搭建路由報錯 router.map is not a function,非常具有實用價值,需要的朋友可以參考下2017-06-06
vue-cli創(chuàng)建項目及項目結(jié)構(gòu)解析
上一篇我們安裝了vue-cli,接下來我們就使用該腳手架進(jìn)行創(chuàng)建項目,這篇文章主要介紹了vue-cli創(chuàng)建項目以及項目結(jié)構(gòu)的相關(guān)資料,需要的朋友可以參考下面文章的具體內(nèi)容2021-10-10
Vuex中this.$store.commit()和this.$store.dispatch()區(qū)別說明
這篇文章主要介紹了Vuex中this.$store.commit()和this.$store.dispatch()區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04
vue+el使用this.$confirm,不能阻斷代碼往下執(zhí)行的解決
這篇文章主要介紹了vue+el使用this.$confirm,不能阻斷代碼往下執(zhí)行的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09
Vue實現(xiàn)contenteditable元素雙向綁定的方法詳解
contenteditable是所有HTML元素都有的枚舉屬性,表示元素是否可以被用戶編輯。本文將詳細(xì)介紹如何實現(xiàn)contenteditable元素的雙向綁定,需要的可以參考一下2022-05-05
詳解vue-router 2.0 常用基礎(chǔ)知識點之router.push()
本篇文章主要介紹了vue-router 2.0 常用基礎(chǔ)知識點之router.push(),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05

