欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

利用VUE框架,实现列表分页功能示例代码

程序员文章站 2022-05-14 07:53:42
先来看一下效果图:     功能描述: 1. 点击页面序号跳转到相应页面; 2. 点击单左/单右,向后/向前跳转...

先来看一下效果图:

利用VUE框架,实现列表分页功能示例代码 

利用VUE框架,实现列表分页功能示例代码 

利用VUE框架,实现列表分页功能示例代码

功能描述:

1. 点击页面序号跳转到相应页面;

2. 点击单左/单右,向后/向前跳转一个页面;

3. 点击双左/双右,直接跳转到最后一页/第一页;

4. 一次显示当前页面的前三个与后三个页面;

5. 始终显示最后一个页面;

html:

 <!-- 分页开始 -->
<div class="u-pages" style="margin-bottom:20px; margin-top:10px;">
 <ul>
   <li v-if="showpre" class="crt"><a v-on:click="jumpfirst(cur)"> << </a></li>
   <li v-if="showpre" class="crt"><a v-on:click="minus(cur)"> < </a></li>

   <template v-for="index in indexs" >
     <li class="{{classrenderer(index)}}">
       <a v-on:click="btnclick(index)" >{{index}}</a>
     </li>
   </template>

   <li v-if="showmoretail" class="crt">..</li>
   <li class="{{classrenderer(pageno)}}"><a @click="btnclick(pageno)">{{pageno}}</a></li>
   <li v-if="showtail" class="crt"><a v-on:click="plus(cur)">></a></li>
   <li v-if="showtail" class="crt"><a v-on:click="jumptail(cur)">>></a></li>

 </ul>
</div>
<!-- 分页结束 -->

html方法分析: 

1、

<li class="{{classrenderer(index)}}">

classrenderer()方法实现了当点击页面索引是,点击页面获得选中效果

2、

<a v-on:click="btnclick(index)" >{{index}}</a> 

btnclick()方法,实现了点击页面索引,跳转到相应页面

showpre showtail

showpre控制跳转到第一页与跳转到前一页的按钮的显示与消除

showtail控制跳转到最后一页与跳转到后一页的按钮的显示与消除

cur

记录当前页序号

jumpfirst(cur) minus(cur) plus(cur) jumptail(cur)

实现按钮跳转功能

js:

 module.exports = {
    data: function () {
      return {
        cur:1,
        showtail:true,
        showmorepre: false,
        showmoretail: false,       

      }
    },
    methods:{
    jumpfirst:function(data){
        var $this = this;
        data = 1;
        $this.cur = data;
        if (data == 1 )
        {
          $this.$set("showpre", false);
        }else
        {
          $this.$set("showpre", true);
        }
        $this.$am.ajax({
          url:window.$apiconf.api_order_detail_list,
          type:'get',
          data:{start: 1},
          success: function(data){
            console.log(data);
            $this.$set("records", data.record.records);
            $this.$set("start", data.record.query.start);
            $this.$set("total", data.record.query.total);
            $this.$set("limit", data.record.query.limit);
          }
        })
        $this.$set("showtail", true);
        return data;
      },
      minus:function(data){
        var $this = this;
        data--;
        $this.cur = data;
        $this.$set("showtail", true);
        if(data == 1){
          $this.$set("showpre", false);

        }else{
          $this.$set("showpre", true);
        }

        $this.$am.ajax({
          url:window.$apiconf.api_order_detail_list,
          type:'get',
          data:{start: 1 + $this.limit * (data-1) },
          success:function(data){
            console.log(data);
            $this.$set("records", data.record.records);
            $this.$set("start", data.record.query.start);
            $this.$set("total", data.record.query.total);
            $this.$set("limit", data.record.query.limit);
          }
        })
        return data;
      },
      plus: function(data){
        var $this = this;
        data++;
        $this.cur = data;
        $this.$set("showpre", true);
        if (data == $this.pageno)
        {
          $this.$set("showtail", false);
        }else
        {
          $this.$set("showtail", true);
        }
        $this.$am.ajax({
          url:/* 这里写上你自己请求数据的路径 */,
          type:'get',
          data:{start: 1 + $this.limit * (data-1) },
          success:function(data){
            console.log(data);
            $this.$set("records", data.record.records);
            $this.$set("start", data.record.query.start);
            $this.$set("total", data.record.query.total);
            $this.$set("limit", data.record.query.limit);
          }
        })
        return data;
      },
      classrenderer:function(index){
        var $this = this;
        var cur = $this.cur;
        if(index != cur){
          return 'crt';
        }
        return '';
      },
      btnclick:function(data){
        var $this = this;
        if(data == 1){
          $this.$set("showpre", false);

        }else{
          $this.$set("showpre", true);
        }
        if (data == $this.pageno)
        {
          $this.$set("showtail", false);
        }else
        {
          $this.$set("showtail", true);
        }
        if (data != $this.cur)
        {
          $this.cur = data;
          $this.$am.ajax({
            url:window.$apiconf.api_order_detail_list,
            type:'get',
            data:{start: 1 + $this.limit * (data-1) },
            success:function(data){
              console.log(data);
              $this.$set("records", data.record.records);
              $this.$set("start", data.record.query.start);
              $this.$set("total", data.record.query.total);
              $this.$set("limit", data.record.query.limit);
            }
          })
        }
      },
      jumptail:function(data){
        var $this = this;
        data = $this.pageno;
        $this.cur = data;
        if (data == $this.pageno)
        {
          $this.$set("showtail", false);
        }else
        {
          $this.$set("showtail", true);
        }
        $this.$am.ajax({
          url:window.$apiconf.api_order_detail_list,
          type:'get',
          data:{start: 1 + $this.limit * (data-1) },
          success:function(data){
            console.log(data);
            $this.$set("records", data.record.records);
            $this.$set("start", data.record.query.start);
            $this.$set("total", data.record.query.total);
            $this.$set("limit", data.record.query.limit);
          }
        })
        $this.$set("showpre", true);
        return data;
      },
     computed: {
      //*********************分页开始******************************//
      indexs: function(){
        var $this = this;
        var ar = [];

        if ($this.cur > 3)
        {
          ar.push($this.cur - 3);
          ar.push($this.cur - 2);
          ar.push($this.cur - 1);

        }else
        {
          for (var i = 1; i < $this.cur; i++)
          {
            ar.push(i);
          }
        }
        if ($this.cur != $this.pageno)
        {
          ar.push($this.cur);
        }

        if ( $this.cur < ( $this.pageno - 3 ) )
        {
          ar.push($this.cur + 1);
          ar.push($this.cur + 2);
          ar.push($this.cur + 3);
          if ( $this.cur < ( $this.pageno - 4 ) )
          {
            $this.$set("showmoretail", true);
          }
        }else
        {
          $this.$set("showmoretail", false);
          for (var i = ($this.cur + 1); i < $this.pageno; i++)
          {
            ar.push(i);
          }
        }
        return ar;
      }
      //*********************分页结束******************************//
    }
}   

js功能分析:indexs用于记录一共有多少页面

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。