色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Vue+Element-U實現分頁顯示效果

瀏覽:3日期:2022-10-28 15:55:18

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

當我們從后端返回的數據量很大,并且根據需求我們需要將返回的數據全部都顯示在頁面中,默認情況下會把所有的數據全部顯示在一個頁面,這樣非常影響視覺和頁面的使用,所以需要使用分頁我這次使用的是Vue4.0 + Element-UI組件,Element-UI庫非常的豐富,它提供了一個分頁組件 Pagination

展示效果:這個是獲取兩個時間段的上機記錄

Vue+Element-U實現分頁顯示效果

HTML部分:

<el-card> <div class='block'> <span style='left:-100px; position:relative'> <span 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 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' @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:這個是一個方法,當在頁面改變每頁顯示的條數時,會觸發該方法

Vue+Element-U實現分頁顯示效果

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

Vue+Element-U實現分頁顯示效果

:current-page:當前頁數

:page-sizes:個數選擇器的選項設置

Vue+Element-U實現分頁顯示效果

:page-size:每頁顯示的條數

:total:總數據數量

JS代碼:

<script>export default { data () { return { value1: ’’, value2: ’’, lineData: [], username: ’’, total: 0, //實現動態綁定 pageSize: 2, currentPage: 1, } }, methods: { //當改變每頁顯示條數的選擇器時會觸發的事件 handleSizeChange (size) { // 每頁顯示的數量是我們選擇器選中的值size this.pageSize = size; console.log(this.pageSize);//每頁下拉顯示數據 this.lineCrodList(); },//當改變當前頁數的時候觸發的事件 handleCurrentChange (currentPage) { this.currentPage = currentPage; console.log(this.currentPage);//點擊第幾頁 this.lineCrodList(); },//獲取用戶上機記錄的信息分頁 async lineCrodList () { //調用 獲取total數據的方法 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) }) }, //獲取用戶總條數 async counttotal () { await this.$http.post(’/Line/selectTotal’, { userName: this.username, onTime: this.value1, downTime: this.value2, }).then(res => { this.total = res.data; })}

我們前端請求的時候需要給后端發送start 和 pageSize 這兩個參數 因為具體的數據是后端通過數據庫來搜索的

后臺Sql語句,其他層的代碼我就不在這里列出

Vue+Element-U實現分頁顯示效果

可以看到 limit i,n

i:表示查詢結果的索引值

n:為查詢結果的返回數量

i 和 n之間用逗號分隔

例子:

#分頁顯示新聞數據,每頁顯示兩條,這里顯示第一頁SELECT id,title,author,createdate FROM news_detail LIMIT 0,2#分頁顯示新聞數據,每頁顯示兩條,這里顯示第二頁SELECT id,title,author,createdate FROM news_detail LIMIT 2,2#分頁顯示新聞數據,每頁顯示兩條,這里顯示第三頁SELECT id,title,author,createdate FROM news_detail LIMIT 4,2#公用的分頁sql#第二個數:分頁后每頁顯示幾條新聞(頁面容量) pageSize#第一個數:從第幾條數據開始顯示(當前頁碼pageNo-1)*pageSizeSELECT id,title,author,createdate FROM news_detail LIMIT (pageNo-1)*pageSize,pageSize

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

Vue+Element-U實現分頁顯示效果

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 亚洲国产成人麻豆精品 | 国产真实女人一级毛片 | 国产性夜夜春夜夜爽30 | 欧美成人全部免费观看1314色 | 成人看片黄a在线观看 | 欧美另类视频一区二区三区 | 成人区在线观看免费视频 | 欧美在线视频一区 | 成年网站免费视频黄 | 天天摸天天爽视频69视频 | 一及 片日本 | 91欧洲在线视精品在亚洲 | 日韩aⅴ在线观看 | 欧美日本国产 | 国产三级做爰高清视频a | 亚洲精品专区一区二区三区 | 亚洲在线免费观看 | 日本三级网站在线观看 | 特级欧美视频aaaaaa | 国产午夜精品理论片在线 | 欧美日韩高清不卡一区二区三区 | 波多野结衣在线观看免费区 | 天堂8中文在线最新版在线 天堂8资源8在线 | 神马国产 | 538prom精品视频在放免费 | 国产精品一区二区三区高清在线 | 狠狠色丁香婷婷久久综合不卡 | 美女双腿打开让男人桶爽网站 | 国产精品视频男人的天堂 | 亚洲自拍中文 | 免费又黄又爽又猛大片午夜 | 亚洲性久久 | 国产精品二区页在线播放 | 久久亚洲视频 | 99久久精品免费看国产免费软件 | 精品欧美高清一区二区免费 | 亚洲成人免费在线视频 | 韩国日本三级在线观看 | 亚洲欧美中文在线观看4 | aaaa欧美高清免费 | 国产真实一区二区三区 |