Maison > développement back-end > tutoriel php > Communication des composants Vue : utilisation de $set pour le transfert de données dynamique

Communication des composants Vue : utilisation de $set pour le transfert de données dynamique

WBOY
Libérer: 2023-07-08 14:14:02
original
1603 Les gens l'ont consulté

Communication des composants Vue : utilisez $set pour le transfert de données dynamique

Le transfert de données entre les composants est une exigence très courante dans le développement de Vue. Dans Vue, vous pouvez utiliser $emit et $on pour établir la communication entre les composants parents et enfants. Dans la plupart des cas, cette approche est suffisante. Cependant, lorsque nous devons ajouter ou supprimer des données de manière dynamique, utiliser $set devient un meilleur choix.

Vue fournit une méthode $set, qui peut être utilisée pour ajouter une propriété réactive à un objet d'instance Vue ou à un objet réactif. Cet ajout de données dynamique peut répondre de manière flexible à nos besoins pendant le processus de développement.

Ce qui suit est un exemple d'utilisation de $set pour le transfert dynamique de données :

Supposons que nous ayons deux composants : Parent et Enfant. Le composant Parent contient un bouton et lorsque vous cliquez sur le bouton, certaines données dynamiques seront transmises au composant Enfant.

// Parent.vue 文件
<template>
  <div>
    <button @click="sendData">传递数据</button>
    <Child :data="data" @updateData="updateData"></Child>
  </div>
</template>

<script>
export default {
  data() {
    return {
      data: {}
    }
  },
  methods: {
    sendData() {
      this.$set(this.data, 'message', 'Hello, Child!')
    },
    updateData(newData) {
      this.data = newData
    }
  }
}
</script>
Copier après la connexion

Dans le composant Parent, nous définissons un objet réactif nommé data et le transmettons au composant Child en tant qu'accessoires. Lorsque vous cliquez sur le bouton, nous utilisons la méthode $set pour ajouter une propriété appelée message à l'objet de données et définir sa valeur sur « Bonjour, mon enfant ! ». Cela permet un transfert de données dynamique.

// Child.vue 文件
<template>
  <div>
    <p>{{ data.message }}</p>
  </div>
</template>

<script> 
export default {
  props: ['data'],
  watch: {
    data: function(newData) {
      this.$emit('updateData', newData)
    }
  }
}
</script>
Copier après la connexion

Dans le composant Enfant, nous recevons l'objet de données transmis par le composant Parent et le restituons dans le modèle. Nous ne modifions pas directement les données dans les accessoires, mais surveillons les changements dans les accessoires et déclenchons un événement pour transmettre les nouvelles données au composant Parent.

Dans le composant parent, nous définissons une méthode updateData pour recevoir les nouvelles données transmises par le composant Enfant et mettre à jour l'objet données du composant parent. Cette méthode garantit un flux de données unidirectionnel et est conforme aux principes de conception de Vue.

Résumé :

La communication entre les composants Vue est une exigence courante dans le processus de développement de Vue. Nous pouvons utiliser les méthodes $emit et $on des composants parent-enfant pour réaliser le transfert de données. Cependant, lorsque nous devons ajouter ou supprimer des données de manière dynamique, l'utilisation de la méthode $set peut mieux répondre à nos besoins. En utilisant la méthode $set, nous pouvons ajouter dynamiquement un attribut réactif à l'objet d'instance Vue ou à l'objet réactif pour réaliser un transfert de données dynamique. Au cours du processus de développement, nous devons choisir la méthode de communication la plus appropriée en fonction des besoins spécifiques afin de garantir la maintenabilité et l'évolutivité du code.

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