基于vue.js實現的分頁
更新時間:2018年03月13日 10:08:54 作者:AmberWu
本文主要給大家介紹基于vue的分頁原生寫法,代碼分為html部分和js部分,簡單易懂,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
本文主要介紹基于vue的分頁原生寫法。
先po上效果圖:

html部分,將page作為一個單獨的組件
<script type="text/x-template" id="page">
<ul class="pagination">
<li v-show="current != 1" @click="current-- && goto(current)">
<a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" >上一頁</a>
</li>
<li v-for="index in pages" @click="goto(index)" :class="{'active':current == index}" :key="index">
<a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" >{{index}}</a>
</li>
<li v-show="allpage != current && allpage != 0 " @click="current++ && goto(current++)">
<a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" >下一頁</a>
</li>
</ul>
</script>
<div id="app">
<page></page>
</div>
js部分:
<script>
Vue.component("page", {
template: "#page",
data: function () {
return {
current: 1, // 當前頁碼
showItem: 5, // 最少顯示5個頁碼
allpage: 13 // 總共的
}
},
computed: {
pages: function () {
var pag = [];
if (this.current < this.showItem) { //如果當前的激活的項 小于要顯示的條數
//總頁數和要顯示的條數那個大就顯示多少條
var i = Math.min(this.showItem, this.allpage);
while (i) {
pag.unshift(i--);
}
} else { //當前頁數大于顯示頁數了
var middle = this.current - Math.floor(this.showItem / 2), //從哪里開始
i = this.showItem;
if (middle > (this.allpage - this.showItem)) {
middle = (this.allpage - this.showItem) + 1
}
while (i--) {
pag.push(middle++);
}
}
return pag
}
},
methods: {
goto: function (index) {
if (index == this.current) return;
this.current = index;
//這里可以發(fā)送ajax請求
}
}
})
var vm = new Vue({
el: '#app',
})
</script>
css部分:
body {
font-family: "Segoe UI";
}
li {
list-style: none;
}
a {
text-decoration: none;
}
.pagination {
position: relative;
}
.pagination li {
display: inline-block;
margin: 0 5px;
}
.pagination li a {
padding: .5rem 1rem;
display: inline-block;
border: 1px solid #ddd;
background: #fff;
color: #0E90D2;
}
.pagination li a:hover {
background: #eee;
}
.pagination li.active a {
background: #0E90D2;
color: #fff;
}
最后附上github地址:https://github.com/AmberWuWu/vue-page
總結
以上所述是小編給大家介紹的基于vue.js實現的分頁,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
相關文章
從vue基礎開始創(chuàng)建一個簡單的增刪改查的實例代碼(推薦)
這篇文章主要介紹了從vue基礎開始創(chuàng)建一個簡單的增刪改查的實例代碼,需要的朋友參考下2018-02-02

