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 相关文章推荐
jquery 分页控件实现代码
Nov 30 Javascript
javascript作用域容易记错的两个地方分析
Jun 22 Javascript
JS实现div居中示例
Apr 17 Javascript
javascript中call apply 的应用场景
Apr 16 Javascript
jQuery的extend方法【三种】
Dec 14 Javascript
详解angularjs结合pagination插件实现分页功能
Feb 10 Javascript
vue-cli脚手架config目录下index.js配置文件的方法
Mar 13 Javascript
利用不到200行代码写一款属于你自己的js类库
Jul 08 Javascript
基于mpvue的简单弹窗组件mptoast使用详解
Aug 02 Javascript
vue与django集成打包的实现方法
Nov 11 Javascript
React学习之JSX与react事件实例分析
Jan 06 Javascript
vue实现lodop打印功能的示例
Nov 11 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
跟我学小偷程序之成功偷取首页(第三天)
2006/10/09 PHP
php5 and xml示例
2006/11/22 PHP
QQ登录 PHP OAuth示例代码
2011/07/20 PHP
thinkphp jquery实现图片上传和预览效果
2020/07/22 PHP
VBS通过WMI监视注册表变动的代码
2011/10/27 Javascript
js实现图片拖动改变顺序附图
2014/05/13 Javascript
javascript监听鼠标滚轮事件浅析
2014/06/05 Javascript
用jquery修复在iframe下的页面锚点失效问题
2014/08/22 Javascript
Javascript限制网页只能在微信内置浏览器中访问
2014/11/09 Javascript
JS和css实现检测移动设备方向的变化并判断横竖屏幕
2015/05/25 Javascript
jquery实现根据浏览器窗口大小自动缩放图片的方法
2015/07/17 Javascript
由浅入深剖析Angular表单验证
2016/07/14 Javascript
Vue.js第四天学习笔记
2016/12/02 Javascript
微信小程序 图片加载(本地,网路)实例详解
2017/03/10 Javascript
javascript基本数据类型和转换
2017/03/17 Javascript
JS实现元素上下左右移动效果
2017/10/18 Javascript
微信小程序获取用户绑定手机号方法示例
2019/07/21 Javascript
nodejs脚本centos开机启动实操方法
2020/03/04 NodeJs
JavaScript实现随机点名小程序
2020/10/29 Javascript
Python3使用requests包抓取并保存网页源码的方法
2016/03/15 Python
解决Python中字符串和数字拼接报错的方法
2016/10/23 Python
Python使用sorted排序的方法小结
2017/07/28 Python
Python排序搜索基本算法之插入排序实例分析
2017/12/11 Python
Python编程深度学习计算库之numpy
2018/12/28 Python
详解python中的线程与线程池
2019/05/10 Python
python将数组n等分的实例
2019/12/02 Python
matplotlib基础绘图命令之bar的使用方法
2020/08/13 Python
学校运动会开幕演讲稿
2014/01/04 职场文书
我爱读书演讲稿
2014/05/07 职场文书
珍惜资源保护环境的建议书
2014/05/14 职场文书
四查四看整改措施
2014/09/19 职场文书
涪陵白鹤梁导游词
2015/02/09 职场文书
工作感想范文
2015/08/07 职场文书
导游词之黄帝陵景区
2019/09/16 职场文书
react中props 的使用及进行限制的方法
2021/04/28 Javascript
Mysql中存储引擎的区别及比较
2021/06/04 MySQL