上一篇文章介绍了vuejs实现的简单分页,如果我有几个页面都需要有分页效果,不可能每个页面都去复制一下这段代码吧,意思是封装一下,变成通用的组件。
首先使用基础 Vue 构造器,创建一个“子类”,Vue.extend( options )
var barHtml = '<div class="page-bar">'+ '<ul>'+ '<li v-if="cur>1"><a v-on:click="cur--,pageClick()">上一页</a></li>'+ '<li v-if="cur==1"><a class="banclick">上一页</a></li>'+ '<li v-for="index in indexs" v-bind:class="{ active: cur == index}">'+ '<a v-on:click="btnclick(index)">{{ index }}</a>'+ '</li>'+ '<li v-if="cur!=all"><a v-on:click="cur++,pageClick()">下一页</a></li>'+ '<li v-if="cur == all"><a class="banclick">下一页</a></li>'+ '<li><a>共<i>{{all}}</i>页</a></li>'+ '</ul>'+ '</div>'; var navBar = Vue.extend({ template:barHtml,props:['all','cur'],computed: { indexs: function(){ var left = 1; var right = this.all; var ar = []; if(this.all>= 5){ this.cur > 3 && this.cur < this.all-2){ left = this.cur - 2 right = this.cur + 2 }else{ this.cur<=3){ left = 1 right = 5 }{ right = .all left = this.all -4 } } } while (left <= right){ ar.push(left) left ++ } return ar } },methods: { btnclick: (data){ if(data != .cur){ this.cur = data; this.$emit('btn-click',data); } },pageClick: (){ this.$emit('btn-click',.cur); } },}); window.pagenav = navBar;
这儿创建了一个全局的pagenav,可以在其它地方都可以调用。
HTML代码
<div id="page"> vue-nav :cur.sync="cur" :all.sync="all" v-on:btn-click="listenDate"></vue-navp style="margin-left:40px;">{{msg}}</p> div>
css代码
.page-bar{ margin:40px; } ul,li{ 0px; padding: 0px; } li{ list-style: none } .page-bar ul{ overflow: hidden; } .page-bar li{ float: left; } .page-bar li:first-child>a { margin-left: 0px } .page-bar a{ display: block; border: 1px solid #ddd; text-decoration: none; position: relative; 6px 12px; margin-left: -1px; line-height: 1.42857143; color: #337ab7; cursor: pointer } .page-bar a:hover{ background-color: #eee; } .page-bar a.banclick{not-allowed; } .page-bar .active a{ #fff; default; border-color: #337ab7; } .page-bar i{ font-style:normal; #d44950; 0px 4px; font-size: 12px; }
新建一个vue对象实例
var pageBar = new Vue({ el: '#page'//总页数 cur: 1,1)">当前页码 msg:'' },components:{ 'vue-nav':pagenav },watch: { cur: (oldValue,newValue){ console.log('监听cur前与后的值:'); console.log(arguments); } },methods:{ listenDate: data; this.msg = '你点击了'+data+ '页'; } } })
简单的用js封装了一下分页组件。
实现效果
<!DOCTYPE htmlhtmlheadMeta name="viewport" content="width=device-width,initial-scale=1.0,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no"/> charset="utf-8"title="keywords"="" ="description"script type="text/javascript" src="js/vue.min2.js"script> .page-bar{ margin:40px; } 0px; padding li list-style none .page-bar ul overflow hidden .page-bar li float left .page-bar li:first-child>a margin-left 0px .page-bar a display block border 1px solid #ddd text-decoration none position relative 6px 12px margin-left -1px line-height 1.42857143 color #337ab7 cursor pointer .page-bar a:hover background-color #eee .page-bar a.banclicknot-allowed .page-bar .active a #fff default border-color .page-bar i font-stylenormal #d44950 0px 4px font-size 12px} body> ="text/javascript"> var barHtml = '<div class="page-bar">+ <ul>+ <li v-if="cur>1"><a v-on:click="cur--,pageClick()">上一页</a></li><li v-if="cur==1"><a class="banclick">上一页</a></li><li v-for="index in indexs" v-bind:class="{ active: cur == index}">+ <a v-on:click="btnclick(index)">{{ index }}</a></li><li v-if="cur!=all"><a v-on:click="cur++,pageClick()">下一页</a></li><li v-if="cur == all"><a class="banclick">下一页</a></li><li><a>共<i>{{all}}</i>页</a></li></ul>+ </div>; navBar =allcurfunction(){ left 1; right this.all; ar []; if(.all>= 5){ .cur > 3 && < -2){ left - right + }else{ .cur<=3 }{ right .all left .all 4 } } } while (left right){ ar.push(left) left ++ } return(data){ (data != .cur){ data; .$emit(btn-click(){ navBar; pageBar new Vue({ el: #page8//总页数 cur: 当前页码 msg:''vue-nav监听cur前与后的值: data; .msg 你点击了+data页; } } }) >