Vue实现web分页组件详解


Posted in Javascript onNovember 28, 2017

本文实例为大家分享了Vue实现web分页组件的具体代码,供大家参考,具体内容如下

效果演示

Vue实现web分页组件详解

源代码

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>测试分页 - www.maoyupeng.com</title>
 <style type="text/css">
  body{padding:0; margin: 0; broder:none; } #app {width: 500px; height: 200px; margin: 0 auto; text-align: center; background-color: #cccccc; } #mylink {color: #efefef; } .pagination{list-style: none; text-align: center; height: 50px; padding-top: 50px; } .pagination > li {float: left; margin: 0 5px; } [v-cloak] {display: none; } </style>
</head>
<body>
 <div id="app" v-cloak>
  <ul class="pagination">
   <li>
    <a v-if="currentPage == 1" >首页</a>
    <a v-else href="javascript:;" @click="next(1)">首页</a>
   </li>
   <li v-if="currentPage<=1"><a>上一页</a></li>
   <li v-else><a href="javascript:;" @click="next(currentPage-1)">上一页</a></li>


   <li v-for="item in pagingList">
    <a v-if="currentPage==item.key || sign ==item.key" >{{item.key}}</a>
    <a v-else href="javascript:;" @click="next(item.value)">{{item.key}}</a>
   </li>

   <li v-if="currentPage>=totalPageCount"><a>下一页</a></li>
   <li v-else><a href="javascript:;" @click="next(currentPage+1)">下一页</a></li>
   <li>
    <a v-if="totalPageCount == currentPage">尾页</a>
    <a v-else href="javascript:;" @click="next(totalPageCount)">尾页</a>
   </li>
  </ul>
  <p>共:{{totalPageCount||0}}页,当前页为第{{currentPage||0}}页   设置总页数:<input style="width:20px;" v-model="totalPageCount"></p>
  <a href="http://www.maoyupeng.com/web-pagination-component-for-vue.html" target="_blank" id="mylink">http://www.maoyupeng.com 带注解版本</a>
 </div>

 <script src="https://unpkg.com/vue/dist/vue.js"></script>
 <script type="text/javascript">
  var app = new Vue({
   el: '#app',
   data: {
   // 省略的符号
   sign:'...',
   // 省略号位置
   signIndex:4,
   // 总页数
   totalPageCount: 4,
   // 当前页
   currentPage:1,
   // 显示在页面的数组列表
   pagingList:[]
   },
   watch: {
   totalPageCount (val) {
    var that = this
    if (!val || val == '') return;
    that.currentPage = 1;
    that.init()
   },
   currentPage (val) {
    var that = this
    that.init()
   }
   },
   methods: {
   // 跳转到某页码
   next (num) {
    var that = this
    if (num <= 1) that.currentPage = 1;
    else if (num >= that.totalPageCount) that.currentPage = that.totalPageCount;
    else that.currentPage = num;
   },
   // 初始化数据
   fetchData () {
    var that = this

    that.pagingList = [];
    var tmp = null;


    if ((that.totalPageCount) > 6) {
     if (((that.totalPageCount-1) == (that.totalPageCount - that.currentPage)) && (that.totalPageCount - that.currentPage) > 5) {
      for (var i=1;i<7;i++) {
       if (i < that.signIndex) {
        tmp = {key:i, value:i }
       } else if (i== that.signIndex) {
        tmp = {key:that.sign, value:0 }
       } else if (i == (that.signIndex + 1) ) {
        tmp = {key:that.totalPageCount - 1, value:that.totalPageCount - 1 }
       } else {
        tmp = {key:that.totalPageCount, value:that.totalPageCount }
       }
       that.pagingList.push(tmp)
      }
     } else if (((that.totalPageCount - that.currentPage) <= that.signIndex)){
      var starNum = that.totalPageCount - 5;
      for (var i=starNum;i<starNum+6;i++) {
       tmp = {key:i, value:i }
       that.pagingList.push(tmp)
      }
     } else {
      var starNum = that.currentPage - 1;
      for (var i=1;i<7;i++) {
       if (i < that.signIndex) {
        tmp = {key:(starNum - 1) + i, value:(starNum - 1) + i }
       } else if (i== that.signIndex) {
        tmp = {key:that.sign, value:0 }
       } else if (i == (that.signIndex + 1) ) {
        tmp = {key:that.totalPageCount - 1, value:that.totalPageCount - 1 }
       } else {
        tmp = {key:that.totalPageCount, value:that.totalPageCount }
       }
       that.pagingList.push(tmp)
      }
     }
    } else {
     for (var i =0; i <that.totalPageCount; i++) {
      tmp = {key:i+1, value:i+1 }
      that.pagingList.push(tmp)
     }
    }
   },
   init () {
    var that = this

    that.fetchData()
   }
   },
   mounted () {
   var that = this

   that.init()
   }
  }) 
 </script>
</body>
</html>

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

Javascript 相关文章推荐
javascript实现原生ajax的几种方法介绍
Sep 21 Javascript
jQuery自带的一些常用方法总结
Sep 03 Javascript
jquery简单实现带渐显效果的选项卡菜单代码
Sep 01 Javascript
利用Javascript实现BMI计算器
Aug 16 Javascript
jQuery插件HighCharts绘制简单2D柱状图效果示例【附demo源码】
Mar 21 jQuery
解决AjaxFileupload 上传时会出现连接重置的问题
Jul 07 Javascript
JS时间控制实现动态效果的实例讲解
Jul 31 Javascript
基于react组件之间的参数传递(详解)
Sep 05 Javascript
详解vue-cli之webpack3构建全面提速优化
Dec 25 Javascript
详解redux异步操作实践
Aug 15 Javascript
Vue替代marquee标签超出宽度文字横向滚动效果
Dec 09 Javascript
深入理解redux之compose的具体应用
Jan 12 Javascript
基于vue2实现左滑删除功能
Nov 28 #Javascript
JavaScript生成简单等差数列
Nov 28 #Javascript
微信小程序用户自定义模版用法实例分析
Nov 28 #Javascript
vue2手机APP项目添加开屏广告或者闪屏广告
Nov 28 #Javascript
浅谈vue中慎用style的scoped属性
Nov 28 #Javascript
元素全屏的设置与监听实例
Nov 28 #Javascript
vue2实现数据请求显示loading图
Nov 28 #Javascript
You might like
PHP生成便于打印的网页
2006/10/09 PHP
php file_get_contents函数轻松采集html数据
2010/04/22 PHP
php算开始时间到过期时间的相隔的天数
2011/01/12 PHP
详细解读PHP的Yii框架中登陆功能的实现
2015/08/21 PHP
Nginx环境下PHP flush失效的解决方法
2016/10/19 PHP
PHP实现用户异地登录提醒功能的方法【基于thinkPHP框架】
2018/03/15 PHP
javascript document.execCommand() 常用解析
2009/12/14 Javascript
js将long日期格式转换为标准日期格式实现思路
2013/04/07 Javascript
JavaScript中的eval()函数使用介绍
2014/12/31 Javascript
js在指定位置增加节点函数insertBefore()用法实例
2015/01/12 Javascript
谈谈对offsetleft兼容性的理解
2015/11/11 Javascript
JS打印组合功能
2016/08/04 Javascript
jQuery EasyUI tree 使用拖拽时遇到的错误小结
2016/10/10 Javascript
ionic2自定义cordova插件开发以及使用(Android)
2017/06/19 Javascript
Webpack设置环境变量的一些误区详解
2019/12/19 Javascript
jquery将信息遍历到界面上实例代码
2020/01/21 jQuery
vue 解决addRoutes多次添加路由重复的操作
2020/08/04 Javascript
详解vue组件之间的通信
2020/08/30 Javascript
Python中实现字符串类型与字典类型相互转换的方法
2014/08/18 Python
python logging 日志轮转文件不删除问题的解决方法
2016/08/02 Python
解决Python字典写入文件出行首行有空格的问题
2017/09/27 Python
Python实现的本地文件搜索功能示例【测试可用】
2018/05/30 Python
20行python代码实现人脸识别
2019/05/05 Python
python实现飞船游戏的纵向移动
2020/04/24 Python
pytorch 实现L2和L1正则化regularization的操作
2021/03/03 Python
关于css中margin的值和垂直外边距重叠问题
2020/10/27 HTML / CSS
Speedo澳大利亚官网:全球领先游泳品牌
2018/02/04 全球购物
美国女士时尚珠宝及配饰购物网站:Icing
2018/07/02 全球购物
法国在线药房:Shop Pharmacie
2019/11/26 全球购物
机械制造专业个人的自我评价
2013/12/28 职场文书
大学生创业感言
2014/01/25 职场文书
《与朱元思书》的教学反思
2014/04/17 职场文书
品牌服务方案
2014/06/03 职场文书
解除劳动合同证明书模板
2014/11/20 职场文书
企业党支部工作总结2015
2015/05/21 职场文书
MyBatis配置文件解析与MyBatis实例演示
2022/04/07 Java/Android