继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

使用Vue开发一个分页插件

lockLuck
关注TA
已关注
手记 6
粉丝 4
获赞 16

组件是Vue最强大的功能之一,可以扩展HTML功能,封装可重用的代码。分页组件是网页中常用的,本篇文章介绍如何简单封装一个分页组件。

我们使用全局注册的方式来开发一个组件,形式如下:

Vue.component('组件名称',{
 ...配置项
});

思路

我们通过props传入参数,在page组件内部计算需要显示的页码。

//props 参数
total       //数据总条数
pagesize    //每页显示数
page        //当前页码

总页数计算:Math.ceil(total/pagesize)

当页码改变时,触发一个pagechange事件,父组件中可以捕获该事件。

代码

 Vue.component('page',{
        props:{
             total:{
               type:[Number,String],
               default:0
             },
             pagesize:{
               type:[Number,String],
               default:1
             },
             page:{
               type:[Number,String],
               default:1
             }
        },
        template:'<div class="page">'+
              '<ul>'+
                '<li :class="page==1?\'disable\':\'\'" @click="prev">上一页</li>'+
                '<li @click="toFirst">首页</li>'+
                '<li v-for="item in list"  :class="[item==page?\'active\':\'\']"  @click="handleClick">'+
                  '{{item}}'+
                '</li>'+
                '<li @click="toEnd">尾页</li>'+
                '<li :class="page==totalCount?\'disable\':\'\'" @click="next">下一页</li>'+
                '<li>总共{{totalCount}}页</li>'+
              '</ul>'+
            '</div>',
        data(){
          return {
            totalCount:0      //总页数
          }
        },
        computed:{
          list(){
            let list=[];
            //计算总页数
            this.totalCount=Math.ceil(this.total/this.pagesize);

            //超限控制
            if(this.page<=0){              
              this.page=1;
            }   
            if(this.page>this.totalCount){
              this.page=this.totalCount;
            }

            //计算显示页码
            if(this.totalCount>5){
              if(this.page>2&&this.page<this.totalCount-2){
                   list=[this.page-2,this.page-1,this.page,this.page+1,this.page+2];
              }else if(this.page<=2&&this.page>0){
                for(let i=1;i<=5;i++){
                  list.push(i);
                }  
              }else if(this.page>=this.totalCount-2&&this.page<=this.totalCount){
                for(let i=4;i>=0;i--){
                  list.push(this.totalCount-i);
                }
              }
            }else{
              for(let i = 1;i<=this.totalCount;i++){
                list.push(i);
              }
            }
            return list;
          }
        },

        methods:{
             //页码点击事件
             handleClick(e){
               let page=parseInt(e.target.innerText);
               let {count,total }=this;
               this.$emit('pagechange',{page,count,total});
             },
             //前一页
             prev(e){
               if(!e.target.classList.contains['disable']){
                   this.page>1&&this.page--;
                   let {page,count,total }=this;
                   this.$emit('pagechange',{page,count,total});
               }
             },
             //下一页
             next(e){
              if(!e.target.classList.contains['disable']){
                   this.page<this.totalCount&&this.page++;
                   let {page,pagesize,total }=this;
                   this.$emit('pagechange',{page,pagesize,total});
               }
             },
             //首页
             toFirst(){
                let {page,pagesize,total }=this;
                this.$emit('pagechange',{page:1,pagesize,total});
             },
             //尾页
             toEnd(){
              let {page,pagesize,total }=this;
              this.$emit('pagechange',{page:this.totalCount,pagesize,total});
             }
         } 
      });

样式

     div.page{
          font-size: 12px;
          font-family:'Franklin Gothic Medium', 'Arial Narrow', Arial, sans-serif;
          color: #666;
          user-select: none;
       }
       div.page ul{
         padding: 0;
         margin:0;
       }
       div.page ul li{
         display: inline-block;
         min-width:30px;
         min-height:30px;
         border-radius:3px;
         line-height: 30px;
         text-align: center;
         margin: 0 6px;
         cursor: pointer;
       }
       div.page ul li.active{
         background: #1796e0;
         color:#fff;
       }
       div.page ul li.disable{
         color: #ccc;
       }
       

使用方式

//html代码
...
<div id="app">
     <page :pagesize="pageSize" :page="page" :total="total" @pageChange="pageChange"></page>
</div>

//js代码
 new Vue({
        el:'#app',
        data:{
            page:1,
            pageSize:5,
            total:100
        },
        methods:{
          pageChange(e){
            this.page=e.page;
          }
        }
 });
...

最终效果:
图片描述

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP