100行代碼實現(xiàn)一個vue分頁組功能
今天用vue來實現(xiàn)一個分頁組件,總體來說,vue實現(xiàn)比較簡單,樣式部分模仿了elementUI。所有代碼的源碼可以再github上下載的到:下載地址 先來看一下實現(xiàn)效果:

整體思路
我們先看一下使用到的文件的目錄:

我們在 pageComponentsTest.vue 頁面引入了 pageComponent.vue 分頁組件。整體思路是通過 props
來達到組件的靈活通用的效果,整體語法是使用vue的VM語法。
pageComponent.vue實現(xiàn)
首先實現(xiàn)一個分頁,需要知道數(shù)據(jù)總條數(shù),一個頁面顯示的數(shù)據(jù)條數(shù)和當前顯示第幾頁的數(shù)據(jù)。那么我們在 pageComponent.vue 里面的 props 就有了??聪旅娴拇a:
props: {
// 分頁配置
pageConfig: {
type: Object, require: true, default() {
return {
pageSize: 10, //一頁的數(shù)據(jù)條數(shù)
pageNo: 0, //當前頁的索引
total: 0, //總的數(shù)據(jù)條數(shù)
pageTotal: 0 //總的頁數(shù)
}
}
}
根據(jù)用戶入?yún)?,我們可以使用計算屬性來計算一個總頁數(shù)的變量:
computed: {
//計算總頁數(shù),如果傳了pageTotal,直接取pageTotal的值,如果傳了total,那么根據(jù)pageSize去計算
pageTotal(){
const config = this.pageConfig
if(config.pageTotal){
return config.pageTotal
}else {
if(config.pageSize && config.total){
return Math.ceil(config.total/config.pageSize)
}else {
return 0
}
}
}
}
有了總頁數(shù),和當前頁,就需要各種判斷來實現(xiàn)我們的html部分了,這里分4中情況
- 總頁數(shù)小于8,只需要直接遍歷到8就行了。
- 總頁數(shù)大于8,但當前頁小于4的。
- 總頁數(shù)大于8,當前頁靠后的。
- 總頁數(shù)大于8,當前頁在中間的。
下面看具體的實現(xiàn):
<!--上一頁-->
<button @click="prePage" :disabled="currentPage === 1">上一頁</button>
<!--總頁數(shù)小于8的-->
<template v-if="pageTotal <= showPageNo">
<button v-for="i in pageTotal" @click="changeCurrentPage(i)" :class="{active:i === currentPage}" :key="i">{{i}}</button>
</template>
<template v-else-if="currentPage < 4">
<button v-for="i in 6" @click="changeCurrentPage(i)" :class="{active:i === currentPage}" :key="i">{{i}}</button>
<button :disabled="true">···</button>
<button>{{pageTotal}}</button>
</template>
<template v-else-if="currentPage > pageTotal - 4">
<button>1</button>
<button :disabled="true">···</button>
<button v-for="i in 6" @click="changeCurrentPage(i + (pageTotal - 6))" :class="{active:(i + (pageTotal - 6)) === currentPage}" :key="i">{{i + (pageTotal - 6)}}</button>
</template>
<template v-else>
<button>1</button>
<button :disabled="true">···</button>
<button @click="changeCurrentPage(currentPage - 2)">{{currentPage - 2}}</button>
<button @click="changeCurrentPage(currentPage - 1)">{{currentPage - 1}}</button>
<button class="active">{{currentPage}}</button>
<button @click="changeCurrentPage(currentPage + 1)">{{currentPage + 1}}</button>
<button @click="changeCurrentPage(currentPage + 2)">{{currentPage + 2}}</button>
<button :disabled="true">···</button>
<button @click="changeCurrentPage(pageTotal)">{{pageTotal}}</button>
</template>
<!--下一頁-->
<button @click="nextPage" :disabled="currentPage === pageTotal">下一頁</button>
可以看到頁面上需要實現(xiàn)3個方法,分別是上下頁,和點擊頁面的方法。
methods: {
prePage(){
this.currentPage -= 1
this.$emit('changeCurrentPage',this.currentPage)
},
nextPage(){
this.currentPage += 1
this.$emit('changeCurrentPage',this.currentPage)
},
changeCurrentPage(i){
this.currentPage = i
this.$emit('changeCurrentPage',this.currentPage)
}
}
以上就是 pageComponent.vue 的大致實現(xiàn)了,每次頁面改變,都會觸發(fā)一個 changeCurrentPage 方法的回調(diào),用來通知當前使用組件的頁面當前頁已經(jīng)改變。
pageComponentsTest.vue的實現(xiàn)
引用頁面就比較簡單了,只要傳入組件需要的對應的參數(shù),就能顯示我們的組件了。 引用部分:
<template> <div class="pageComponentsTest"> <page-component :page-config="pageConfigTotal" @changeCurrentPage="changePage"></page-component> <page-component :page-config="pageConfigPageTotal"></page-component> </div> </template>
配合入?yún)⒉糠郑?/p>
{
name: "pageComponentsTest",
data() {
return {
pageConfigTotal:{total:21,pageSize:10,pageNo:1},
pageConfigPageTotal:{total:21,pageSize:10,pageNo:1,pageTotal:50}
}
},
components:{'page-component':pageComponent},
methods: {
changePage(page){
this.pageConfigTotal.pageNo = page
}
}
}
總結(jié)
可以看到使用vue實現(xiàn)分頁組件整體來說是很容易了,比使用jQuery方便很多,使用vm模式開發(fā)前端的最明顯的一個好處是,能是數(shù)據(jù)mode部分與view頁面部分保持同步,而開發(fā)者不用考慮這個過程,所以整體來說簡單了很多。
以上所述是小編給大家介紹的100行代碼實現(xiàn)一個vue分頁組功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
vue項目開發(fā)中setTimeout等定時器的管理問題
這篇文章主要介紹了vue項目開發(fā)中setTimeout等定時器的管理問題,需要的朋友可以參考下2018-09-09

