vue+Element-ui前端實(shí)現(xiàn)分頁(yè)效果
本文實(shí)例為大家分享了vue+Element-ui前端實(shí)現(xiàn)分頁(yè)效果的具體代碼,供大家參考,具體內(nèi)容如下
分頁(yè)技術(shù)
分頁(yè)技術(shù)的概念
分頁(yè)就是將所有的數(shù)據(jù)分段展示給用戶(hù),用戶(hù)看到的可能不是全部的數(shù)據(jù),而是其中一部分,用戶(hù)可以通過(guò)點(diǎn)擊頁(yè)碼來(lái)查找自己需要的內(nèi)容,也可以通過(guò)模糊查詢(xún)獲取符合內(nèi)容的數(shù)據(jù)
分頁(yè)的意義
分頁(yè)確實(shí)有效,但它一定會(huì)加大系統(tǒng)的復(fù)雜度,但可否不分頁(yè)呢?如果數(shù)據(jù)量少的話當(dāng)然可以.但是對(duì)于企業(yè)信息系統(tǒng)來(lái)說(shuō)數(shù)據(jù)量不會(huì)限制在一個(gè)小范圍內(nèi).如果不顧一切的Select * from某個(gè)表,再將返回的數(shù)據(jù)一古腦的扔給客戶(hù),即使客戶(hù)能夠忍受成千上萬(wàn)足夠讓人眼花繚亂的表格式數(shù)據(jù),繁忙的網(wǎng)絡(luò),緊張的服務(wù)器也會(huì)提出它們無(wú)聲的抗議,甚至有時(shí)會(huì)以徹底的罷工
前端實(shí)現(xiàn)分頁(yè)效果
在el-tree控件中將內(nèi)容按照一個(gè)頁(yè)面顯示十條數(shù)據(jù),來(lái)實(shí)現(xiàn)分頁(yè)的效果
實(shí)現(xiàn)效果:el-tree
<template> <div class='big'> <div class='top'> <el-input placeholder='搜索' v-model='searchData' @input='search'></el-input> </div> <div class='middle'> <el-tree :data='list'> <span slot-scope='{ node, data }'> <span class='el-icon-tickets'></span> <span>{{data.name}} {{data.age}}</span> </span> </el-tree> </div> <div class='bottom'> <el-pagination @size-change='handleSizeChange' @current-change='handleCurrentChange' background :current-page='page' :page-size='limit' layout='prev, pager, next' :total='total'></el-pagination> </div> </div></template>
<script> export default { data() { return { data: [{ name: ’aa’, age: 12 }, { name: ’bb’, age: 13 } ],//列舉一部分的數(shù)據(jù) list: [], // 顯示的數(shù)據(jù) limit: 10, // 條數(shù),每一頁(yè)顯示的數(shù)量 total: 20, // 所有的數(shù)量 page: 1, //當(dāng)前頁(yè) searchData: ’’ // 搜索內(nèi)容 } }, created() { this.pageList() }, methods: { pageList() { this.getList() }, // 處理數(shù)據(jù) getList() { // es6過(guò)濾得到滿足搜索條件的展示數(shù)據(jù)list var list = this.data.filter((item, index) => item.name.includes(this.searchData) ) // 搜索符號(hào)條件的內(nèi)容 console.log(list) this.list = list.filter((item, index) => index < this.page * this.limit && index >= this.limit * (this.page - 1) ) //根據(jù)頁(yè)數(shù)顯示相應(yīng)的內(nèi)容 this.total = list.length }, // 當(dāng)每頁(yè)數(shù)量改變 handleSizeChange(val) { console.log(`每頁(yè) ${val} 條`); this.limit = val this.getList() }, // 當(dāng)當(dāng)前頁(yè)改變 handleCurrentChange(val) { console.log(`當(dāng)前頁(yè): ${val}`); this.page = val this.getList() }, // 搜索過(guò)濾數(shù)據(jù) search() { this.page = 1 this.getList() } }, }</script>
el-table實(shí)現(xiàn)分頁(yè)效果也是類(lèi)似的
展示效果
html的代碼,js的代碼和tree的分頁(yè)差不多,el-table的分頁(yè)添加了可以選擇顯示的數(shù)量,以及跳轉(zhuǎn)頁(yè)碼
<div class='big'> <el-row> <el-col :span='21'> <el-input v-model='searchData' @input='search' placeholder='輸入姓名搜索'></el-input> </el-col> <el-col :span='3'> <el-button type='success' @click='search'>搜索</el-button> </el-col> </el-row> <el-table :data='list' border> <el-table-column label='姓名' prop='name'></el-table-column> <el-table-column label='年齡' prop='age'></el-table-column> </el-table> <div style='text-align: center;'> <el-pagination @size-change='handleSizeChange' @current-change='handleCurrentChange' :current-page='page' :page-sizes='[1, 2,5, 10]' :page-size='limit' layout='total, sizes, prev, pager, next, jumper' :total='total'> </el-pagination> </div></div>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. React+umi+typeScript創(chuàng)建項(xiàng)目的過(guò)程2. ASP.NET Core 5.0中的Host.CreateDefaultBuilder執(zhí)行過(guò)程解析3. SharePoint Server 2019新特性介紹4. ASP中常用的22個(gè)FSO文件操作函數(shù)整理5. 三個(gè)不常見(jiàn)的 HTML5 實(shí)用新特性簡(jiǎn)介6. ASP調(diào)用WebService轉(zhuǎn)化成JSON數(shù)據(jù),附j(luò)son.min.asp7. .Net core 的熱插拔機(jī)制的深入探索及卸載問(wèn)題求救指南8. 無(wú)線標(biāo)記語(yǔ)言(WML)基礎(chǔ)之WMLScript 基礎(chǔ)第1/2頁(yè)9. 讀大數(shù)據(jù)量的XML文件的讀取問(wèn)題10. 解決ASP中http狀態(tài)跳轉(zhuǎn)返回錯(cuò)誤頁(yè)的問(wèn)題
