Maison > interface Web > Questions et réponses frontales > Comment passer des appels entre les composants vue

Comment passer des appels entre les composants vue

WBOY
Libérer: 2023-05-27 17:23:08
original
1074 Les gens l'ont consulté

Vue est un framework JavaScript très populaire dans le développement Web moderne, dont les composants constituent une partie très importante. Dans Vue, les composants peuvent être réutilisés, et la communication entre les composants est également un problème souvent rencontré en développement. Cet article présentera les problèmes de communication entre les composants Vue et explorera en détail comment « passer des appels » entre les composants Vue.

1. Communication entre les composants Vue

Dans Vue, la communication entre les composants est principalement divisée en deux manières : la communication entre les composants parent-enfant et la communication entre les composants non parent-enfant.

1. Communication entre les composants parent-enfant

Dans les composants Vue, les composants parents peuvent transmettre des données aux composants enfants via des accessoires.

Modèle de composant parent :

<template>
  <div>
    <child :message="message"></child>
  </div>
</template>
Copier après la connexion

Script du composant enfant :

<script>
  export default {
    props: ['message']
  }
</script>
Copier après la connexion

La façon dont le composant parent transmet les données au composant enfant est très simple. Il vous suffit d'ajouter l'attribut props à l'étiquette du composant enfant et d'augmenter les données de transfert requises. par le composant enfant.

Après avoir reçu les données transmises par le composant parent, le composant enfant peut utiliser ces données dans le modèle :

<template>
  <div>
    {{message}}
  </div>
</template>
Copier après la connexion

La transmission de données au composant enfant via des accessoires est l'une des méthodes de communication parent-enfant les plus couramment utilisées dans Vue. En pratique, nous pouvons également avoir besoin d'exécuter les méthodes du composant parent ou de manipuler les données du composant parent. Dans ce cas, l'événement émis peut être utilisé pour communiquer entre le composant parent et le composant enfant.

Composant parent :

<template>
  <div>
    <child @sendMsg="updateMessage"></child>
  </div>
</template>

<script>
  export default {
    data () {
      return {
        message: ''
      }
    },
    methods: {
      updateMessage (msg) {
        this.message = msg
      }
    }
  }
</script>
Copier après la connexion

Utilisez la méthode $emit pour déclencher l'événement sendMsg dans le composant enfant

<script>
  export default {
    methods: {
      sendMessage () {
        this.$emit('sendMsg', 'Hello Vue!')
      }
    }
  }
</script>
Copier après la connexion

2 Communication entre composants non parent-enfant

Dans Vue, si le composant n'est pas une relation parent-enfant, alors. la communication entre les composants peut utiliser le bus d'événements du fournisseur officiel Vue.

Méthode d'implémentation spécifique :

Créer un nouveau fichier eventBus.js

import Vue from 'vue'

export const eventBus = new Vue()
Copier après la connexion

Dans le composant qui doit communiquer, importer eventBus.js et utiliser $emit pour déclencher l'événement :

<script>
  import { eventBus } from './eventBus.js'

  export default {
    methods: {
      sendMessage () {
        eventBus.$emit('sendMsg', 'Hello Vue!')
      }
    }
  }
</script>
Copier après la connexion

Recevoir l'événement :

<template>
  <div>
    <h1>{{ message }}</h1>
  </div>
</template>

<script>
  import { eventBus } from './eventBus.js'

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

This Cette méthode peut rendre la communication entre les composants différente, mais elle présente certains inconvénients : lorsque l'application est très complexe, il est difficile de retracer les liens de communication entre les composants.

2. Méthodes de communication et sélections entre les composants

Pendant le processus de développement d'une application, il est nécessaire de choisir une méthode de communication adaptée à l'application afin d'améliorer l'efficacité et les performances du développement.

1. La communication des composants parent-enfant

convient aux situations où les composants parent-enfant doivent transférer des données ou effectuer des opérations. Cette méthode est relativement simple et facile à maintenir et à déboguer.

2. Communication entre composants non parent-enfant

Applicable aux situations où une communication est requise entre les niveaux croisés, les frères et d'autres composants non parent-enfant. L'utilisation de la méthode du bus d'événements peut simplement implémenter la communication entre les composants, mais elle peut facilement entraîner des difficultés de débogage et une complexité accrue.

3.Vuex

Vuex est la bibliothèque de gestion d'état officiellement fournie par Vue, qui est utilisée pour gérer l'état (y compris les données et les opérations) dans l'application. Convient aux projets plus importants lorsque de grandes quantités de données doivent être partagées.

En utilisant Vuex, vous pouvez placer la communication entre les composants dans le magasin Vuex, puis laisser les composants requis obtenir les données dans le magasin via des getters ou utiliser des actions pour déclencher des changements d'état dans le magasin, mettre à jour les données dans le magasin et puis informez les autres composants.

Résumé :

Dans le développement de Vue, la communication entre les composants est un problème courant. Nous pouvons choisir la communication entre composants parent-enfant, la communication entre composants non parent-enfant et Vuex pour la gestion de l'état en fonction de la situation réelle. Une utilisation appropriée de ces méthodes peut améliorer l’efficacité et les performances du développement d’applications.

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