Maison > interface Web > Voir.js > Utilisez le composant keep-alive pour implémenter la gestion de l'état au niveau de la page Vue

Utilisez le composant keep-alive pour implémenter la gestion de l'état au niveau de la page Vue

PHPz
Libérer: 2023-07-21 09:19:53
original
1287 Les gens l'ont consulté

Utilisez le composant keep-alive pour implémenter la gestion de l'état au niveau de la page Vue

Dans Vue, la gestion de l'état est un sujet important. Normalement, nous utilisons Vuex pour gérer l'état global. Mais parfois, nous pouvons avoir besoin de partager l'état entre différentes pages au lieu de l'état global. À l'heure actuelle, nous pouvons utiliser le composant keep-alive de Vue pour implémenter la gestion de l'état au niveau de la page. Le composant

keep-alive est un composant abstrait fourni par Vue, qui peut mettre en cache des instances de composants dynamiques et conserver leur état lorsque les composants changent. En utilisant le composant keep-alive, nous pouvons facilement implémenter la gestion de l'état au niveau de la page.

Ci-dessous, j'utiliserai un exemple pour montrer comment utiliser le composant keep-alive pour implémenter la gestion de l'état au niveau de la page.

Tout d'abord, nous créons une application Vue simple et définissons deux composants dans App.vue : Accueil et Profil.

<template>
  <div>
    <router-view />
  </div>
</template>

<script>
export default {
  name: 'App'
}
</script>
Copier après la connexion

Ensuite, nous configurons la route dans main.js et enveloppons la vue de la route avec le composant keep-alive.

import Vue from 'vue'
import App from './App.vue'
import VueRouter from 'vue-router'
import Home from './components/Home.vue'
import Profile from './components/Profile.vue'

Vue.use(VueRouter)

const routes = [
  { path: '/', component: Home },
  { path: '/profile', component: Profile }
]

const router = new VueRouter({
  mode: 'history',
  routes
})

new Vue({
  router,
  render: h => h(App)
}).$mount('#app')
Copier après la connexion

Dans Home.vue, nous définissons un simple composant de compteur et l'enveloppons avec le composant keep-alive.

<template>
  <div>
    <h2>Home</h2>
    <keep-alive>
      <Counter :count="count" />
    </keep-alive>
    <button @click="increment">Increment</button>
  </div>
</template>

<script>
import Counter from './Counter.vue'

export default {
  name: 'Home',
  components: {
    Counter
  },
  data() {
    return {
      count: 0
    }
  },
  methods: {
    increment() {
      this.count++
    }
  }
}
</script>
Copier après la connexion

Dans Profile.vue, nous définissons également un composant compteur et l'enveloppons avec le composant keep-alive.

<template>
  <div>
    <h2>Profile</h2>
    <keep-alive>
      <Counter :count="count" />
    </keep-alive>
    <button @click="increment">Increment</button>
  </div>
</template>

<script>
import Counter from './Counter.vue'

export default {
  name: 'Profile',
  components: {
    Counter
  },
  data() {
    return {
      count: 0
    }
  },
  methods: {
    increment() {
      this.count++
    }
  }
}
</script>
Copier après la connexion

Enfin, nous définissons un composant compteur Counter.vue, qui reçoit une propriété count et affiche la valeur actuelle du compteur.

<template>
  <div>
    <p>Count: {{ count }}</p>
  </div>
</template>

<script>
export default {
  name: 'Counter',
  props: {
    count: {
      type: Number,
      default: 0
    }
  }
}
</script>
Copier après la connexion

Maintenant, nous pouvons exécuter l'application et tester la gestion de l'état au niveau de la page.

Lorsque nous cliquons sur le bouton "Incrémenter" sur la page d'accueil, seul le compteur de la page d'accueil augmentera. Cependant, lorsque nous passons à la page Profil et revenons à la page d'accueil, la valeur du compteur dans la page d'accueil reste inchangée.

L'utilisation du composant keep-alive peut facilement réaliser une gestion du statut au niveau de la page. Il met automatiquement en cache les instances de composants dynamiques et préserve leur état lorsque les composants changent. De cette façon, nous pouvons partager l'état entre différentes pages.

Dans cet exemple, nous utilisons le composant keep-alive pour implémenter la gestion de l'état au niveau de la page, mais le principe peut également être appliqué à d'autres scénarios. J'espère que cet article pourra vous aider à mieux comprendre et utiliser le composant keep-alive de Vue.

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!

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