这篇文章主要为大家详细介绍了Vue中的无限加载vue-infinite-loading的方法,具有一定的参考价值,可以用来参考一下。
感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!
本文介绍了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>
本文借鉴://www.q1010.com/article/137896.htm
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持四海网。
本文来自:http://www.q1010.com/184/4977-0.html
注:关于Vue中的无限加载vue-infinite-loading的方法的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。
关键词:vue.js
四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。