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

Vue+Element-U實現(xiàn)分頁顯示效果

 更新時間:2020年11月15日 15:14:34   作者:赫于富  
這篇文章主要為大家詳細介紹了Vue+Element-U實現(xiàn)分頁顯示效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了Vue+Element-U實現(xiàn)分頁顯示效果的具體代碼,供大家參考,具體內(nèi)容如下

當我們從后端返回的數(shù)據(jù)量很大,并且根據(jù)需求我們需要將返回的數(shù)據(jù)全部都顯示在頁面中,默認情況下會把所有的數(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:這個是一個方法,當在頁面改變每頁顯示的條數(shù)時,會觸發(fā)該方法

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

:current-page:當前頁數(shù)

:page-sizes:個數(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: {
 //當改變每頁顯示條數(shù)的選擇器時會觸發(fā)的事件
 handleSizeChange (size) {
 // 每頁顯示的數(shù)量是我們選擇器選中的值size
 this.pageSize = size;
 console.log(this.pageSize);//每頁下拉顯示數(shù)據(jù)
 this.lineCrodList();
 },
//當改變當前頁數(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ù)開始顯示(當前頁碼pageNo-1)*pageSize
SELECT id,title,author,createdate FROM news_detail 
LIMIT (pageNo-1)*pageSize,pageSize

我把(pageNo-1)*pageSize 寫到了前端,所以就無需在后端重復寫

# 查詢8條數(shù)據(jù),索引從5到12,第6條記錄到第13條記錄 select * from t_user limit 5,8;

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論