当前位置: 移动技术网 > IT编程>脚本编程>vue.js > Vue中的无限加载vue-infinite-loading的方法

Vue中的无限加载vue-infinite-loading的方法

2018年04月25日  | 移动技术网IT编程  | 我要评论

电脑报合订本,樊耀明,人tys

本文介绍了vue中的无限加载vue-infinite-loading的方法,分享给大家,具体如下:

注意:vue-infinite-loading2.0只能在vue.js2.0中使用。如果你想在vue.js1.0中使用,请安装vue-infinite-loading1.3版本

如何安装

npm install vue-infinite-loading --save

导入方式

es6模块导入方式

import infiniteloading from 'vue-infinite-loading';
export default {
 components: {
  infiniteloading
 },
};

commonjs 模块导入方式

const infiniteloading = require('vue-infinite-loading');
export default {
 components: {
   infiniteloading
 }
};

其他方式

<script src="vue-infinite-loading.js"></script>

在页面中应用

直接在组件中声明

components:{
  infiniteloading
}

模板部分

<infinite-loading @infinite="infinitehandler">
  <span slot="no-more">
     我们是有底线的
  </span>
</infinite-loading>

js部分

当滚动到底部时自动触发infinitehandler事件

infinitehandler($state) {
     settimeout(() => {
       const temp = [];
       for (let i = this.list.length + 1; i <= this.list.length + 20; i++) {
         temp.push(i);
       }
       this.list = this.list.concat(temp);
       $state.loaded();
       $state.complete();
     }, 1000);
}

注意

如果还是使用
this.$refs.infiniteloading.$emit('$infiniteloading:loaded');
this.$refs.infiniteloading.$emit('$infiniteloading:complete');
会出现警告,告诉你已经修改为传参传入$state使用这个方法。

属性

distance:这是滚动的临界值。如果到滚动父元素的底部距离小于这个值,那么infinitehandler回调函数就会被调用。

<infinite-loading @infinite="infinitehandler" distance="number">
</infinite-loading>

spinner:通过这个属性,你可以选择一个你最喜爱旋转器作为加载动画。
spinner="bubbles";
1、bubbles
2、circles
3、default
4、spiral
5、wavedots

<infinite-loading @infinite="infinitehandler" spinner="string">
</infinite-loading>

direction:如果你设置这个属性为top,那么这个组件将在你滚到顶部的时候,调用infinitehandler函数。

警告:你必须在数据加载后,手动地将滚动父元素的scrolltop设置为正确的值,否则,该组件会一次又一次调用infinitehandler函数。

direction="top"

<infinite-loading @infinite="infinitehandler" direction="string">
</infinite-loading>

本文借鉴:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网