您好,欢迎访问一九零五行业门户网

使用vue-infinite-loading实现无限加载功能

这次给大家带来使用vue-infinite-loading实现无限加载功能,使用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>
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
使用webpack插件html-webpack-plugin实例详解
怎么实现微信小程序登录鉴权
以上就是使用vue-infinite-loading实现无限加载功能的详细内容。
其它类似信息

推荐信息