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 相关文章推荐
深入理解javaScript中的事件驱动
May 21 Javascript
Jquery元素追加和删除的实现方法
May 24 Javascript
深入浅析JS Function()构造函数
Aug 22 Javascript
vue.js入门教程之基础语法小结
Sep 01 Javascript
详解能在多种前端框架下使用的表格控件
Jan 11 Javascript
JavaScript代码判断输入的字符串是否含有特殊字符和表情代码实例
Aug 17 Javascript
限时抢购-倒计时的完整实例(分享)
Sep 17 Javascript
浅谈vue中使用图片懒加载vue-lazyload插件详细指南
Oct 23 Javascript
详解关于element级联选择器数据回显问题
Feb 20 Javascript
小程序实现投票进度条
Nov 20 Javascript
在Vue中使用antv的示例代码
Jun 29 Javascript
原生js实现弹窗消息动画
Nov 20 Javascript
微信小程序如何获取地址
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的安全策略
2006/10/09 PHP
php的正则处理函数总结分析
2008/06/20 PHP
基于php-fpm的配置详解
2013/06/03 PHP
使用Thinkphp框架开发移动端接口
2015/08/05 PHP
YII2自动登录Cookie总是失效的解决方法
2017/06/28 PHP
javascript 页面只自动刷新一次
2009/07/10 Javascript
javascript自定义函数参数传递为字符串格式
2014/07/29 Javascript
js实现文本框中输入文字页面中div层同步获取文本框内容的方法
2015/03/03 Javascript
json+jQuery实现的无限级树形菜单效果代码
2015/08/27 Javascript
详解AngularJS中$http缓存以及处理多个$http请求的方法
2016/02/06 Javascript
js enter键激发事件实例代码
2016/08/17 Javascript
前端弹出对话框 js实现ajax交互
2016/09/09 Javascript
D3.js实现文本的换行详解
2016/10/14 Javascript
Vue数据驱动模拟实现1
2017/01/11 Javascript
原生javascript实现图片放大镜效果
2017/01/18 Javascript
Vue.js父与子组件之间传参示例
2017/02/28 Javascript
JavaScript编写一个贪吃蛇游戏
2017/03/09 Javascript
微信小程序tabbar不显示解决办法
2017/06/08 Javascript
Vue的路由动态重定向和导航守卫实例
2018/03/17 Javascript
Vue 样式绑定的实现方法
2019/01/15 Javascript
express如何解决ajax跨域访问session失效问题详解
2019/06/20 Javascript
vue更改数组中的值实例代码详解
2020/02/07 Javascript
深入浅析python 中的匿名函数
2018/05/21 Python
python 读取txt,json和hdf5文件的实例
2018/06/05 Python
Python 一句话生成字母表的方法
2019/01/02 Python
如何在Django中添加没有微秒的 DateTimeField 属性详解
2019/01/30 Python
对Python的多进程锁的使用方法详解
2019/02/18 Python
Django模板导入母版继承和自定义返回Html片段过程解析
2019/09/18 Python
Python可变对象与不可变对象原理解析
2020/02/25 Python
一文解决django 2.2与mysql兼容性问题
2020/07/15 Python
python全栈开发语法总结
2020/11/22 Python
python程序实现BTC(比特币)挖矿的完整代码
2021/01/20 Python
泰国国际航空公司官网:Thai Airways International
2019/12/04 全球购物
党员自我评价2015
2015/03/03 职场文书
2015年社区平安建设工作总结
2015/05/13 职场文书
Html5生成验证码的示例代码
2021/05/10 Javascript