vue实现分页加载效果


Posted in Javascript onDecember 24, 2019

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

vue实现分页加载效果

HTML

<!-- 商品 页数-->
 <div class="pagenavi">
  <div class="all-number">
  <span>共{{data.length}}个商品</span>
  </div>
  <p class="pageArea" data-countpage="1">
  <span class="colf22e01 fontT">{{pages}}</span>
  /
  <span class="page_count fontT">{{total}}</span>
  </p>
 </div>
 <div class="clear-b"></div>
 </div>
 
 <!--限制加载数量-->
 <ul class="cata_choose_product clearfix">
 <!--渲染数据  从那个下标开始加载-->
 <li v-for="(value,index) in data" v-if="index < 5">
  <div class="nosinglemore"></div>
  <div class="listbox clearfix">
   <div class="listPic">
   <router-link target="_blank" to="/goods_detail">
    <img :src="value.image" class="fn_img_lazy">
   </router-link>
   </div>
  <div class="listDescript">
   <router-link target="_blank" to="/goods_detail" class="text13">{{value.name}}</router-link>
   </div>
  <div class="cat-shopprice lf">
  <p><span>¥{{value.price}}</span></p>
  </div>
   <div class="cat-addcart lf">
   <div class="cart_wrapper">
    <router-link target="_blank" to="/goods_detail">查看详情</router-link>
   </div>
   </div>
   <div class="clear-b"></div>
  </div>
 </li>
 <div class="clear-b"></div>
 </ul>
 
 <!--分页器-->
<div class="box">
 <div class="box_one">
  <div @click="shan">上一页</div>
  <!--动态生成页数标签-->
  <div class="box_cen">
  <div v-for="(value,index) in total" class="box_foot">
  <span @click="yesu" :id="index">{{index+1}}</span>
  </div>
  </div>
  <div @click="xia">下一页</div>
 </div>
</div>

js

data(){
 return{
 data:"",//页面数据
 num:0,
 pages:1,//当前页数
 priceQuery:false,//价格排序判断
 Total:"",//总页数(向上取整)
 initial:4,//默认加载数量
 total:"",//最终页数
 }
 },
 created(){
 //获取初始数据
 axios.get("'../../static/mock/data.json").then(res=>{
 this.Total = res.data.goods[0].foods.length;
 var arr = [];
 //限制获取数据量
 for(var i=0;i<this.initial;i++){
 //加载数据  页数+数量
 arr.push(res.data.goods[0].foods[this.num+i]);
 }
 this.data = arr;
 this.total = Math.ceil(this.Total/this.data.length);
 }).catch(err=>{
 console.log(err);
 }); 
 },
 methods:{
 //下一页
 xia(){
 //页数++
 if(this.pages == this.total){
  this.pages = this.total;
 }else{
  this.pages++;
 }
 //从 加载数据 下标+数量
 this.num = (this.pages-1)*this.initial;
 this.sua();
 },
 //上一页
 shan(){
 if(this.pages == 1){
  this.pages = 1;
 }else{
  this.pages--;
 }
 this.num = (this.pages-1)*this.initial;
 this.sua();
 },
 //刷新数据
 sua(){
 axios.get("'../../static/mock/data.json").then(res=>{
 var arr = [];
 //限制获取数据量
 for(var i=0;i<this.initial;i++){
 //判断数据是否有undefined,有undefined会报错无法加载
 if(res.data.goods[0].foods[this.num+i] != undefined) arr.push(res.data.goods[0].foods[this.num+i]);
 }
 this.data = arr;
 }).catch(err=>{
 console.log(err);
 }); 
 },
 //页数选择
 yesu(e){
// console.log(e.target.id);
 this.num = (e.target.id)*4;
 this.pages = Number(e.target.id)+1;
 this.sua();
 },

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

Javascript 相关文章推荐
JS的replace方法详细介绍
Nov 09 Javascript
dreamweaver 8实现Jquery自动提示
Dec 04 Javascript
JavaScript获取页面中第一个锚定文本的方法
Apr 03 Javascript
JS基于面向对象实现的放烟花效果
May 07 Javascript
js HTML5 Ajax实现文件上传进度条功能
Feb 13 Javascript
js上下视差滚动简单实现代码
Mar 07 Javascript
jQuery中animate()的使用方法及解决$(”body“).animate({“scrollTop”:top})不被Firefox支持的问题
Apr 04 jQuery
webpack4的迁移的使用方法
May 25 Javascript
VUE脚手架具体使用方法
May 20 Javascript
原生JavaScript实现拖动校验功能
Sep 29 Javascript
解决js中的setInterval清空定时器不管用问题
Nov 17 Javascript
vue+django实现下载文件的示例
Mar 24 Vue.js
微信小程序如何获取地址
Dec 24 #Javascript
浅析vue-router中params和query的区别
Dec 24 #Javascript
JavaScript实现英语单词题库
Dec 24 #Javascript
iSlider手机端图片滑动切换插件使用详解
Dec 24 #Javascript
微信小程序自定义模态弹窗组件详解
Dec 24 #Javascript
js实现鼠标点击页面弹出自定义文字效果
Dec 24 #Javascript
javascript实现鼠标点击生成文字特效
Dec 24 #Javascript
You might like
php出现web系统多域名登录失败的解决方法
2014/09/30 PHP
php使用PDO方法详解
2014/12/27 PHP
php随机抽奖实例分析
2015/03/04 PHP
PHP常用的排序和查找算法
2015/08/06 PHP
如何在Mozilla Gecko 用Javascript加载XSL
2007/01/09 Javascript
JQuery实现点击div以外的位置隐藏该div窗口
2013/09/13 Javascript
js实现仿百度瀑布流的方法
2015/02/05 Javascript
jQuery实现新消息闪烁标题提示的方法
2015/03/11 Javascript
JavaScript计算两个日期时间段内日期的方法
2015/03/16 Javascript
php+ajax+jquery实现点击加载更多内容
2015/05/03 Javascript
深入理解Angular2 模板语法
2016/08/07 Javascript
vue-router跳转页面的方法
2017/02/09 Javascript
React组件生命周期详解
2017/07/03 Javascript
JavaScript实现滑动导航栏效果
2017/08/30 Javascript
原生JS进行前后端同构
2018/04/22 Javascript
Vue将页面导出为图片或者PDF
2020/08/17 Javascript
vue Element左侧无限级菜单实现
2020/06/10 Javascript
[43:32]Winstrike vs VGJ.S 2018国际邀请赛淘汰赛BO3 第一场 8.23
2018/08/24 DOTA
用Python输出一个杨辉三角的例子
2014/06/13 Python
基于scrapy实现的简单蜘蛛采集程序
2015/04/17 Python
使用Python脚本将绝对url替换为相对url的教程
2015/04/24 Python
Python读写/追加excel文件Demo分享
2018/05/03 Python
python aiohttp的使用详解
2019/06/20 Python
win10子系统python开发环境准备及kenlm和nltk的使用教程
2019/10/14 Python
Python如何用filter函数筛选数据
2020/03/05 Python
Django设置Postgresql的操作
2020/05/14 Python
利用python3筛选excel中特定的行(行值满足某个条件/行值属于某个集合)
2020/09/04 Python
python连接mysql数据库并读取数据的实现
2020/09/25 Python
法国购买隐形眼镜和眼镜网站:Optical Center
2019/10/08 全球购物
手机业务员岗位职责
2013/12/13 职场文书
爱国卫生月实施方案
2014/02/21 职场文书
简单的项目建议书模板
2014/03/12 职场文书
信息技术毕业生自荐信范文
2014/03/13 职场文书
房屋买卖协议书范本
2014/09/27 职场文书
导游词之澳门玫瑰圣母堂
2019/12/03 职场文书
JavaScript 原型与原型链详情
2021/11/02 Javascript