vue实现前端分页完整代码


Posted in Javascript onJune 17, 2020

本文实例为大家分享了vue实现前端分页的具体代码,供大家参考,具体内容如下

首先,做出来的效果如图所示,具体的Ajax请求数据可以写在点击函数中
分页效果算是比较费脑子的,里面计算有些麻烦,本文上完整代码,一起学习进步

vue实现前端分页完整代码

  • “上一页”写两个li元素,如果已经是第一页,那么就禁止鼠标点击,如果不是就curr减减,并且可以点击
  • 同理“下一页”也一样
  • 中间部分是通过indexs循环,indexs通过computed计算得出
<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>

难点就是IF嵌套语句

1、每次显示5个数据,如果大于3,范围从3到6,如果到达7,那么下边加2变成9,已经超过最大的范围值,所以最大范围到6
2、如果是大于6,那么最大值就是最大值,最小变成all-4
3、如果3以内,默认不跳动

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){
      //这里最大范围从3到6,如果到达7,那么下边加2变成9,已经超过最大的范围值
      if(this.cur > 3 && this.cur < this.all-1){
       //以4为参考基准,左面加2右边加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 ++
    }
    console.log(ar);
    return ar
    }
  }
})

全部代码:

<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"/>
<meta charset="utf-8">
<title></title>
<meta name="keywords" content="" />
<meta name="description" content="" />
<script type="text/javascript" src="js/vue.min.js"></script>
<style>
.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;
}
</style>
</head>
<body>
 <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>
<script type="text/javascript">
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){
      //这里最大范围从3到6,如果到达7,那么下边加2变成9,已经超过最大的范围值
      if(this.cur > 3 && this.cur < this.all-1){
       //以4为参考基准,左面加2右边加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 ++
    }
    console.log(ar);
    return ar
    }
  }
})
</script>
</body>
</html>

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

Javascript 相关文章推荐
用函数式编程技术编写优美的 JavaScript
Nov 25 Javascript
JS下高效拼装字符串的几种方法比较与测试代码
Apr 15 Javascript
JS中跨页面调用变量和函数的方法(例如a.js 和 b.js中互相调用)
Nov 01 Javascript
Vue.js学习示例分享
Feb 05 Javascript
详解axios在node.js中的post使用
Apr 27 Javascript
js+html制作简单日历的方法
Jun 27 Javascript
ionic App问题总结系列之ionic点击系统返回键退出App
Aug 19 Javascript
基于twbsPagination.js分页插件使用心得(分享)
Oct 21 Javascript
小程序中英文混合排序问题解决
Aug 02 Javascript
javascript/jquery实现点击触发事件的方法分析
Nov 11 jQuery
js点击事件的执行过程实例分析【冒泡与捕获】
Apr 11 Javascript
解决Nuxt使用axios跨域问题
Jul 06 Javascript
JS实现网站楼层导航效果代码实例
Jun 16 #Javascript
利用webpack理解CommonJS和ES Modules的差异区别
Jun 16 #Javascript
JS 5种遍历对象的方式
Jun 16 #Javascript
js实现小球在页面规定的区域运动
Jun 16 #Javascript
Vue结合路由配置递归实现菜单栏功能
Jun 16 #Javascript
vue 实现在同一界面实现组件的动态添加和删除功能
Jun 16 #Javascript
详解JS预解析原理
Jun 16 #Javascript
You might like
php过滤所有恶意字符(批量过滤post,get敏感数据)
2014/03/18 PHP
php使用ereg验证文件上传的方法
2014/12/16 PHP
初识laravel5
2015/03/02 PHP
基于Laravel5.4实现多字段登录功能方法示例
2017/08/11 PHP
浅谈PHP匿名函数和闭包
2019/03/08 PHP
js 图片轮播(5张图片)
2008/12/30 Javascript
JavaScript定时器详解及实例
2013/08/01 Javascript
js中call与apply的用法小结
2013/12/28 Javascript
JS实现统计复选框选中个数并提示确定与取消的方法
2015/07/01 Javascript
jquery动画效果学习笔记(8种效果)
2015/11/13 Javascript
第六篇Bootstrap表格样式介绍
2016/06/21 Javascript
Jquery Easyui进度条组件Progress使用详解(8)
2020/03/26 Javascript
浅析javaScript中的浅拷贝和深拷贝
2017/02/15 Javascript
jQuery Validate 相关参数及常用的自定义验证规则
2017/03/06 Javascript
jquery中封装函数传递当前元素的方法示例
2017/05/05 jQuery
vue组件中使用iframe元素的示例代码
2017/12/13 Javascript
jQuery+ajax实现动态添加表格tr td功能示例
2018/04/23 jQuery
three.js利用卷积法如何实现物体描边效果
2019/11/27 Javascript
如何基于js判断浏览器版本
2020/02/20 Javascript
如何通过Proxy实现JSBridge模块化封装
2020/10/22 Javascript
elementui实现预览图片组件二次封装
2020/12/29 Javascript
element-ui 弹窗组件封装的步骤
2021/01/22 Javascript
Python根据区号生成手机号码的方法
2015/07/08 Python
python下读取公私钥做加解密实例详解
2017/03/29 Python
python儿童学游戏编程知识点总结
2019/06/03 Python
Python with用法:自动关闭文件进程
2019/07/10 Python
Django Model层F,Q对象和聚合函数原理解析
2020/11/12 Python
python 进制转换 int、bin、oct、hex的原理
2021/01/13 Python
CSS3盒子模型详解
2013/04/24 HTML / CSS
AmazeUI 列表的实现示例
2020/08/17 HTML / CSS
几个数据库方面的面试题
2016/07/01 面试题
3D空间设计学生找工作的自我评价
2013/10/28 职场文书
会计顶岗实习心得
2014/01/25 职场文书
见习报告格式范文
2014/11/08 职场文书
会计工作态度自我评价
2015/03/06 职场文书
中学生清明节演讲稿
2015/03/18 职场文书