JavaScript

超轻量级php框架startmvc

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

更新时间:2020-07-05 00:06:01 作者:startmvc
本文介绍了Vue中的无限加载vue-infinite-loading的方法,分享给大家,具体如下:注意:vue-infini

本文介绍了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.jb51.net/article/137896.htm

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

Vue 无限加载 vue-infinite-loading vue infinite loading