注意: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" distance="200" ref="infiniteLoading">
<span slot="no-more">
我們是有底線的
</span>
</infinite-loading>
js部分
當滾動到底部時自動觸發(fā)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');
會出現(xiàn)警告哩罪,告訴你已經(jīng)修改為傳參傳入$state使用這個方法。
屬性
distance:這是滾動的臨界值。如果到滾動父元素的底部距離小于這個值片排,那么infiniteHandler回調(diào)函數(shù)就會被調(diào)用。
<infinite-loading @infinite="infiniteHandler" distance="Number">
</infinite-loading>
spinner:通過這個屬性速侈,你可以選擇一個你最喜愛旋轉(zhuǎn)器作為加載動畫率寡。
spinner="bubbles";
1、bubbles
2倚搬、circles
3冶共、default
4、spiral
5每界、waveDots
<infinite-loading @infinite="infiniteHandler" spinner="String">
</infinite-loading>
direction:如果你設(shè)置這個屬性為top,那么這個組件將在你滾到頂部的時候捅僵,調(diào)用infiniteHandler函數(shù)。
警告:你必須在數(shù)據(jù)加載后眨层,手動地將滾動父元素的scrollTop設(shè)置為正確的值庙楚,否則,該組件會一次又一次調(diào)用infiniteHandler函數(shù)谐岁。
direction="top"
<infinite-loading @infinite="infiniteHandler" direction="String">
</infinite-loading>
當加載到底部后重置需要執(zhí)行
this.$refs.infiniteLoading.$emit('$InfiniteLoading:reset');