您好,登錄后才能下訂單哦!
當(dāng)前組件依賴bootstrap樣式,使用前請(qǐng)先引用相關(guān)css。
Vue.component('pagination', { template: `<nav aria-label="Page navigation"> <ul class="pagination"> <li :class="{'disabled': pageNum == 1}"><a href="#" v-on:click.prevent="turnToPage(1)" title="首頁(yè)" aria-label="首頁(yè)"><i class="fa fa-fast-backward"></i></a></li> <li :class="{'disabled': pageNum == 1}"><a href="#" v-on:click.prevent="turnToPage(pageNum - 1)" title="上一頁(yè)" aria-label="上一頁(yè)"><i class="fa fa-backward"></i></a></li> <li v-if="pageNum > 4"><a href="#" v-on:click.prevent="turnToPage(pageNum - 4)">...</a></li> <li v-if="pageNum <= 4 && pageNum >1"><a href="#" v-on:click.prevent="turnToPage(1)">1</a></li> <li v-if="pageNum - 3 > 1"><a href="#" v-on:click.prevent="turnToPage(pageNum - 3)">{{pageNum-3}}</a></li> <li v-if="pageNum - 2 > 1"><a href="#" v-on:click.prevent="turnToPage(pageNum - 2)">{{pageNum-2}}</a></li> <li v-if="pageNum - 1 > 1"><a href="#" v-on:click.prevent="turnToPage(pageNum - 1)">{{pageNum-1}}</a></li> <li class="active"><a href="#" v-on:click.prevent="turnToPage(pageNum)">{{pageNum}}</a></li> <li v-if="pageNum + 1 < pageTotal"><a href="#" v-on:click.prevent="turnToPage(pageNum + 1)">{{pageNum+1}}</a></li> <li v-if="pageNum + 2 < pageTotal"><a href="#" v-on:click.prevent="turnToPage(pageNum + 2)">{{pageNum+2}}</a></li> <li v-if="pageNum + 3 < pageTotal"><a href="#" v-on:click.prevent="turnToPage(pageNum + 3)">{{pageNum+3}}</a></li> <li v-if="pageNum >= pageTotal - 4 && pageNum < pageTotal"><a href="#" v-on:click.prevent="turnToPage(pageTotal)">{{pageTotal}}</a></li> <li v-if="pageNum < pageTotal - 4"><a href="#" v-on:click.prevent="turnToPage(pageNum + 4)">...</a></li> <li :class="{'disabled': pageNum == pageTotal}"><a href="#" v-on:click.prevent="turnToPage(pageNum + 1)" title="下一頁(yè)" aria-label="下一頁(yè)"><i class="fa fa-forward"></i></a></li> <li :class="{'disabled': pageNum == pageTotal}"><a href="#" v-on:click.prevent="turnToPage(pageTotal)" title="尾頁(yè)" aria-label="尾頁(yè)"><i class="fa fa-fast-forward"></i></a></li> </ul> </nav>`, props: { pageNum: Number, pageSize: Number, totalItemCount: Number, }, computed: { pageTotal: function () { return Math.ceil(this.totalItemCount / this.pageSize) } }, methods: { turnToPage: function (num) { if (num > this.pageTotal || num <= 0) { //toastr.error(`當(dāng)前頁(yè)碼超出了范圍。頁(yè)碼:${num}`, '錯(cuò)誤') return false } this.$emit('change', num) } } })
props定義三個(gè)屬性:當(dāng)前頁(yè)碼,當(dāng)前頁(yè)顯示數(shù)量,總數(shù)量
computed定義了一個(gè)計(jì)算方法:獲取總數(shù)量/當(dāng)前頁(yè)顯示數(shù)量,向上取整,默認(rèn)取10個(gè)
methods定義了一個(gè)根據(jù)頁(yè)碼跳轉(zhuǎn)方法:最終用于觸發(fā)change事件,$emit用于拋出自定義事件,組件外可以捕獲當(dāng)前定義的change事件
html組件顯示:
let vm = new Vue({ el: '#app', data: { criteria: { keyword: '', page: { num: 1, size: 10 } }, itemsCount: 0 }, methods: { skiptoPage: function (num) { this.criteria.page.num = num; } } });
以上方法是自定義事件change的方法,你們可以自己去修改內(nèi)容。
效果圖
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。