Maison > interface Web > Voir.js > Meilleures pratiques pour la communication des composants Vue

Meilleures pratiques pour la communication des composants Vue

PHPz
Libérer: 2023-07-17 17:32:14
original
788 Les gens l'ont consulté

Meilleures pratiques pour la communication des composants Vue

Vue.js est un framework JavaScript très populaire qui fournit une solution de développement front-end légère et évolutive. Dans Vue.js, les composants constituent l'unité de base pour créer des interfaces utilisateur et la communication entre les composants est très importante. Cet article présentera les meilleures pratiques pour la communication des composants Vue et fournira quelques exemples de code.

1. Communication entre composants parent-enfant

La communication entre composants parent-enfant est la forme la plus courante et la plus simple dans le développement de Vue. Les composants parents peuvent transmettre des données aux composants enfants via les attributs props, et les composants enfants peuvent transmettre des données aux composants parents via des événements.

Par exemple, nous avons un composant parent et un composant enfant :

// 父组件
<template>
  <div>
    <child-component :message="message" @update="updateMessage"></child-component>
  </div>
</template>

<script>
import ChildComponent from './ChildComponent.vue';

export default {
  components: {
    ChildComponent
  },
  data() {
    return {
      message: ''
    };
  },
  methods: {
    updateMessage(newMessage) {
      this.message = newMessage;
    }
  }
}
</script>

// 子组件
<template>
  <div>
    <input type="text" v-model="inputMessage" @input="updateParentMessage">
  </div>
</template>

<script>
export default {
  data() {
    return {
      inputMessage: ''
    };
  },
  methods: {
    updateParentMessage() {
      this.$emit('update', this.inputMessage);
    }
  }
}
</script>
Copier après la connexion

Dans le code ci-dessus, le composant parent transmet le message au composant enfant via l'attribut props. Lorsque le composant enfant modifie la valeur de inputMessage dans la zone de saisie, il déclenche l'événement de mise à jour via this.$emit('update', this.inputMessage) et transmet la valeur de inputMessage au composant parent. La méthode updateMessage du composant parent reçoit la valeur transmise par le composant enfant et met à jour la valeur du message.

2. Communication entre les composants frères et sœurs

La communication entre les composants frères et sœurs doit être réalisée à l'aide du bus d'événements de l'instance Vue. Les événements peuvent être écoutés et déclenchés via les méthodes $on et $emit de l'instance Vue.

Par exemple, nous avons deux composants brother :

// 兄弟组件1
<template>
  <div>
    <button @click="sendMessage">发送消息给兄弟组件2</button>
  </div>
</template>

<script>
export default {
  methods: {
    sendMessage() {
      this.$root.$emit('send-message', 'Hello from BrotherComponent1');
    }
  }
}
</script>

// 兄弟组件2
<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      message: ''
    };
  },
  created() {
    this.$root.$on('send-message', (message) => {
      this.message = message;
    });
  }
}
</script>
Copier après la connexion

Dans le code ci-dessus, le composant brother 1 déclenche l'événement d'envoi de message via this.$root.$emit('send-message', 'Hello from BrotherComponent1') , et transmet le message au composant frère 2. Le composant Brother 2 écoute l'événement d'envoi de message via this.$root.$on('send-message', (message) => { this.message = message; }) et attribue le message au message.

3. Communication entre composants à plusieurs niveaux

Lorsque la hiérarchie entre les composants est relativement profonde, il sera plus difficile de communiquer à l'aide d'accessoires et d'événements. À l'heure actuelle, Vuex peut être utilisé pour réaliser une communication de composants à plusieurs niveaux.

Vuex est le mode de gestion d'état de Vue.js. Il stocke l'état de tous les composants dans un objet global. Les composants peuvent communiquer en obtenant et en modifiant les données de l'objet.

Par exemple, nous avons un composant parent et un composant petit-enfant :

// 父组件
<template>
  <div>
    <grandson-component></grandson-component>
  </div>
</template>

<script>
import GrandsonComponent from './GrandsonComponent.vue';

export default {
  components: {
    GrandsonComponent
  }
}
</script>

// 孙子组件
<template>
  <div>
    <p>{{ message }}</p>
    <button @click="updateMessage">更新消息</button>
  </div>
</template>

<script>
export default {
  computed: {
    message() {
      return this.$store.state.message;
    }
  },
  methods: {
    updateMessage() {
      this.$store.commit('updateMessage', 'Hello from GrandsonComponent');
    }
  }
}
</script>

// Vuex状态管理
import Vue from 'vue';
import Vuex from 'vuex';

Vue.use(Vuex);

export default new Vuex.Store({
  state: {
    message: ''
  },
  mutations: {
    updateMessage(state, newMessage) {
      state.message = newMessage;
    }
  }
});
Copier après la connexion

Dans le code ci-dessus, le composant petit-fils récupère la valeur du message enregistrée dans le composant parent via this.$store.state.message et la transmet sur le bouton cliquez sur l'événement this.$store.commit('updateMessage', 'Hello from GrandsonComponent') met à jour la valeur du message. Le composant parent et le composant petit-enfant accèdent à l'objet global Vuex via this.$store.

Grâce aux exemples ci-dessus, nous comprenons les meilleures pratiques pour la communication des composants Vue. Au cours du processus de développement de Vue, le choix de la méthode de communication appropriée selon différents scénarios peut mieux améliorer la réutilisabilité et la maintenabilité des composants. J'espère que cet article pourra vous aider à mieux comprendre et appliquer les méthodes de communication des composants 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