Maison  >  Article  >  interface Web  >  Vue Infinite Loading Explication détaillée de l'utilisation de Vue-Infinite-Loading

Vue Infinite Loading Explication détaillée de l'utilisation de Vue-Infinite-Loading

php中世界最好的语言
php中世界最好的语言original
2018-05-02 09:39:434230parcourir

Cette fois, je vais vous apporter une explication détaillée de l'utilisation de Vue infinite chargement vue-infinite-loading Quelles sont les précautions pour Vue infinite chargement vue-infinite-loading Voici un cas pratique. . Jetons un coup d'oeil.

Cet article présente la méthode de chargement infini de vue-infinite-loading dans Vue et la partage avec tout le monde. Les détails sont les suivants :

Remarque : vue-infinite-loading2.0 ne peut que. être utilisé dans Vue.js2 utilisé dans .0. Si vous souhaitez l'utiliser dans Vue.js1.0, veuillez installer la version vue-infinite-loading1.3

Comment installer

npm install vue-infinite-loading --save

Méthode d'importation

Méthode d'importation du module ES6

import InfiniteLoading from 'vue-infinite-loading';
export default {
 components: {
  InfiniteLoading
 },
};

Méthode d'importation du module CommonJS

const InfiniteLoading = require('vue-infinite-loading');
export default {
 components: {
   InfiniteLoading
 }
};

Autres méthodes

<script src="vue-infinite-loading.js"></script>

dans Appliquer

directement dans le composant et déclarer la

components:{
  InfiniteLoading
}

partie modèle

<infinite-loading @infinite="infiniteHandler">
  <span slot="no-more">
     我们是有底线的
  </span>
</infinite-loading>

partie js

Déclenchez automatiquement l'événement infiniteHandler lors du défilement vers le bas

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);
}

Remarque

Si vous utilisez toujours
this.$ refs.infiniteLoading .$emit('$InfiniteLoading:loaded');
this.$refs.infiniteLoading.$emit('$InfiniteLoading:complete');
Un avertissement apparaîtra, vous indiquant qu'il a été modifié pour transmettre des paramètres dans l'état $ utilise cette méthode.

Attributs

distance : C'est la valeur critique pour le défilement. Si la distance jusqu'au bas de l'élément parent scroll est inférieure à cette valeur, la fonction de rappel infiniteHandler sera appelée.

<infinite-loading @infinite="infiniteHandler" distance="Number">
</infinite-loading>

spinner : Avec cet attribut, vous pouvez choisir l'un de vos spinners préférés comme animation de chargement.
spinner="bubbles";
1, bulles
2, cercles
3, par défaut
4, spirale
5, waveDots

<infinite-loading @infinite="infiniteHandler" spinner="String">
</infinite-loading>

direction : Si vous définissez cette propriété sur top, alors ce composant appellera la fonction infiniteHandler lorsque vous faites défiler vers le haut.

Attention : vous devez définir manuellement le scrollTop de l'élément parent scroll sur la valeur correcte après le chargement des données, sinon le composant appellera la fonction infiniteHandler encore et encore.

direction="top"

<infinite-loading @infinite="infiniteHandler" direction="String">
</infinite-loading>

Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le php. Site chinois !

Lecture recommandée :

Explication détaillée de l'utilisation du remplacement à chaud du module Webpack

Explication détaillée de l'utilisation inter-domaines de proxyTable procuration

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn