使用vuejs2.0怎么实现一个分页

这篇文章给大家介绍使用vuejs2.0怎么实现一个分页,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

“只有客户发展了,才有我们的生存与发展!”这是成都创新互联的服务宗旨!把网站当作互联网产品,产品思维更注重全局思维、需求分析和迭代思维,在网站建设中就是为了建设一个不仅审美在线,而且实用性极高的网站。创新互联对成都网站制作、成都网站设计、网站制作、网站开发、网页设计、网站优化、网络推广、探索永无止境。

css

.page-bar{
  margin:40px;
}
ul,li{
  margin: 0px;
  padding: 0px;
}
li{
  list-style: none
}
.page-bar li:first-child>a {
  margin-left: 0px
}
.page-bar a{
  border: 1px solid #ddd;
  text-decoration: none;
  position: relative;
  float: left;
  padding: 6px 12px;
  margin-left: -1px;
  line-height: 1.42857143;
  color: #337ab7;
  cursor: pointer
}
.page-bar a:hover{
  background-color: #eee;
}
.page-bar a.banclick{
  cursor:not-allowed;
}
.page-bar .active a{
  color: #fff;
  cursor: default;
  background-color: #337ab7;
  border-color: #337ab7;
}
.page-bar i{
  font-style:normal;
  color: #d44950;
  margin: 0px 4px;
  font-size: 12px;
}

模版


  
        1">上一页     上一页            {{ index }}          下一页     下一页     
  • {{all}}
  •   

js

var pageBar = new Vue({
  el: '.page-bar',
  data: {
    all: 20, //总页数
    cur: 1,//当前页码
});

调用 new Vue({参数}) 就是创建了一个基本的组件,赋值给变量 pageBar.

el就是element的缩写,定位模版的位置.data就是数据了.

知道了总页数但是要显示页码还是要一番计算,所以显示页码就是计算属性了.

所以我们要用computed 

computed: {
    indexs: function(){
     var left = 1;
     var right = this.all;
     var ar = [];
     if(this.all>= 5){
      if(this.cur > 3 && this.cur < this.all-2){
          left = this.cur - 2
          right = this.cur + 2
      }else{
        if(this.cur<=3){
          left = 1
          right = 5
        }else{
          right = this.all
          left = this.all -4
        }
      }
     }
    while (left <= right){
      ar.push(left)
      left ++
    }
    return ar
    }
     
  }

 看一下页面显示出来的循环:


    {{ index }}
  

v-for是循环渲染输出计算属性indexs.每一次循环的子元素赋值给index v-bind:class绑定class,当渲染到目前的角标的时候加个class v-on:click是绑定了事件,我把index当参数传进入了,后面做判断,默认传event事件.
然后我们给Vue的选项里面再增加methods字段

methods: {
    btnClick: function(data){//页码点击事件
      if(data != this.cur){
        this.cur = data 
      }
    },
    pageClick: function(){
      console.log('现在在'+this.cur+'页');
    }
  },

组件交互

组件写完了,问题来了,用户点击发生页面改变,你怎么通知其他组件作出相应的变化. 可以在页角发生改变的函数下,插一条语句通知其他组件。不过这种方法是很差的做法。可以使用

watch: {
    cur: function(oldValue , newValue){
      console.log(arguments);
    }
  }

观察了cur数据当它改变的时候,可以获取前后值。然后通知其他组件。

完整的代码:













 
  
        1">上一页     上一页            {{ index }}          下一页     下一页     
  • {{all}}
  •   
var pageBar = new Vue({   el: '.page-bar',   data: {     all: 8, //总页数     cur: 1//当前页码   },   watch: {     cur: function(oldValue , newValue){       console.log(arguments);     }   },      methods: {     btnClick: function(data){//页码点击事件       if(data != this.cur){         this.cur = data        }     },     pageClick: function(){       console.log('现在在'+this.cur+'页');     }   },      computed: {     indexs: function(){      var left = 1;      var right = this.all;      var ar = [];      if(this.all>= 5){       if(this.cur > 3 && this.cur < this.all-2){           left = this.cur - 2           right = this.cur + 2       }else{         if(this.cur<=3){           left = 1           right = 5         }else{           right = this.all           left = this.all -4         }       }      }     while (left <= right){       ar.push(left)       left ++     }     return ar     }         } })

关于使用vuejs2.0怎么实现一个分页就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


文章标题:使用vuejs2.0怎么实现一个分页
本文地址:http://cdiso.cn/article/geisod.html

其他资讯