您好,登錄后才能下訂單哦!
本文介紹了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>
本文借鑒:https://www.jb51.net/article/137896.htm
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。