Maison > interface Web > Voir.js > Comment obtenir un effet de préchargement de page avec le composant keep-alive dans vue

Comment obtenir un effet de préchargement de page avec le composant keep-alive dans vue

WBOY
Libérer: 2023-07-21 19:29:23
original
1593 Les gens l'ont consulté

Comment obtenir un effet de préchargement de page avec le composant keep-alive dans Vue

Dans le développement de Vue, nous rencontrons souvent des changements de page fréquents. À ce stade, si le composant est restitué à chaque changement de page, non seulement le composant sera restitué à chaque changement de page. la vitesse de chargement des pages diminue, est lente et peut perdre certaines données demandées. Afin de résoudre ce problème, Vue fournit un composant keep-alive très pratique, qui peut mettre en cache les composants et obtenir un effet de préchargement de page.

Le composant keep-alive est un composant abstrait intégré à Vue. Il peut mettre en cache les composants commutés dynamiquement afin qu'ils puissent être utilisés directement en cas de besoin la prochaine fois. En utilisant le composant keep-alive, nous pouvons obtenir l'effet de conserver les composants déjà chargés lors du changement d'itinéraire, évitant ainsi les rendus répétés et les nouvelles demandes de données. Ensuite, nous expliquerons en détail comment utiliser le composant keep-alive pour obtenir l'effet de préchargement de page.

Tout d'abord, nous devons installer Vue et créer un projet Vue. Vous pouvez utiliser Vue CLI ou introduire directement un script Vue dans un fichier HTML pour créer une instance Vue. Dans les exemples suivants, nous supposons que Vue a été installée et qu'une instance racine a été créée.

<!DOCTYPE html>
<html>
<head>
  <title>Vue Keep-alive Demo</title>
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
</head>
<body>
  <div id="app">
    <button @click="changePage">切换页面</button>
    <keep-alive>
      <component :is="currentPage"></component>
    </keep-alive>
  </div>

  <script>
    // 创建组件A
    const ComponentA = {
      template: '<div>组件A</div>',
      created() {
        console.log('组件A被创建了');
      }
    };

    // 创建组件B
    const ComponentB = {
      template: '<div>组件B</div>',
      created() {
        console.log('组件B被创建了');
      }
    };

    // 创建Vue实例
    new Vue({
      el: '#app',
      data() {
        return {
          currentPage: 'ComponentA'
        };
      },
      methods: {
        changePage() {
          this.currentPage = this.currentPage === 'ComponentA' ? 'ComponentB' : 'ComponentA';
        }
      },
      components: {
        ComponentA,
        ComponentB
      }
    });
  </script>
</body>
</html>
Copier après la connexion

Dans l'exemple ci-dessus, nous avons créé deux composants ComponentA et ComponentB, et ajouté un attribut currentPage dans l'attribut data de l'instance racine pour marquer le composant actuellement affiché. Dans l'événement de clic sur le bouton, nous changeons le composant affiché en modifiant la valeur de la propriété currentPage.

À l'intérieur du composant keep-alive, nous utilisons des composants dynamiques pour restituer le composant actuel. Il convient de noter que lors de l'utilisation du composant keep-alive, nous devons envelopper le composant qui doit être mis en cache dans le composant keep-alive et restituer le composant actuel via un composant dynamique. De cette façon, chaque fois que vous changez de composant, Vue mettra automatiquement en cache le composant avant de basculer. La prochaine fois que vous passerez au même composant, le composant mis en cache sera utilisé directement sans nouveau rendu.

Dans cet exemple, nous générons les journaux de création de composants dans les fonctions de hook de création de ComponentA et ComponentB respectivement. Nous pouvons cliquer sur le bouton pour passer respectivement au composant A et au composant B, puis revenir au composant précédent. Observez la sortie de la console du navigateur. Nous pouvons constater que lors du retour au composant précédent, la fonction de hook créée n'est pas. déclenché, indiquant que le composant est mis en cache.

Grâce à l'exemple ci-dessus, nous pouvons voir comment utiliser le composant keep-alive pour obtenir l'effet de préchargement de la page. L'utilisation de composants keep-alive peut éviter le rendu répété des composants et la nouvelle demande de données, améliorant ainsi la vitesse de chargement des pages et l'expérience utilisateur.

Cependant, il convient de noter que le keep-alive n’est pas une panacée. Pour certains composants qui doivent mettre à jour les données en temps réel, ou pour certains composants qui contiennent déjà une logique d'interaction utilisateur, nous ne souhaitons peut-être pas les mettre en cache. Dans ce cas, nous pouvons spécifier les composants qui n'ont pas besoin d'être mis en cache en configurant l'attribut d'exclusion du composant keep-alive.

Pour résumer, l'utilisation de composants keep-alive peut simplifier le développement de projets Vue et améliorer la vitesse de chargement des pages et l'expérience utilisateur. Cependant, le composant keep-alive doit être configuré et utilisé correctement en fonction de la situation réelle pour obtenir les meilleurs résultats. J'espère que l'introduction ci-dessus pourra aider tout le monde à comprendre et à utiliser le composant keep-alive.

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal