今回は、vue-infinite-loading を使用して無限ロードを実現する方法についていくつかの notes を紹介します。
注: 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イベントを自動的にトリガーする
一番下までスクロールすると注意
まだ
this.$refs.infiniteLoading.$emit('$InfiniteLoading:loaded');
this.$refs.infiniteLoading.$emit('$InfiniteLoading:complete');を使用している場合、
プロパティ
距離: これはスクロールの重要な値です。スクロールの親要素の下部までの距離がこの値より小さい場合、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); }
<infinite-loading @infinite="infiniteHandler" distance="Number"> </infinite-loading>
<infinite-loading @infinite="infiniteHandler" spinner="String"> </infinite-loading>
webpack プラグイン html-webpack-plugin の詳細な使用例
以上がvue-infinite-loading を使用して無限ロード機能を実現しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。