Maison >interface Web >Voir.js >Comment utiliser les fonctions de bus d'événements dans la documentation Vue

Comment utiliser les fonctions de bus d'événements dans la documentation Vue

WBOY
WBOYoriginal
2023-06-21 08:53:15988parcourir

Comment utiliser la fonction de bus d'événements dans la documentation Vue

Dans le développement de Vue, nous avons souvent besoin de transférer des données ou d'appeler des méthodes entre différents composants. Le bus d'événements offre un moyen simple et flexible de mettre en œuvre la communication entre les composants.

Le bus d'événements fait partie de l'instance Vue et permet aux composants de communiquer entre eux. En termes simples, le bus d'événements est une instance de Vue qui peut être utilisée pour la communication entre les composants. En d'autres termes, nous pouvons utiliser le bus d'événements pour réaliser le transfert d'informations et l'appel de méthodes entre les composants.

Utilisation :

La première étape de l'utilisation du bus d'événements consiste à l'instancier dans une instance Vue. Nous pouvons instancier un bus d'événements dans le fichier main.js et le monter sur le prototype Vue.

import Vue from 'vue'
Vue.prototype.$bus = new Vue()

Dans le code ci-dessus, nous avons ajouté un objet $bus à l'instance Vue via Vue.prototype. et l'avons attribué à une nouvelle instance Vue. De cette façon, nous pouvons communiquer entre les composants via l'objet $bus. Vue.prototype. 的方式在Vue实例上添加了一个 $bus 对象,并将它赋值为一个新的Vue实例。这样我们就可以通过 $bus 对象来进行组件之间的通信了。

使用事件总线进行事件的发布和订阅

接下来我们就可以使用 $bus 对象来进行事件的发布和订阅了。我们可以在需要订阅事件的组件中使用 $bus.$on() 方法来订阅事件,当事件被触发时,就会执行回调函数。

例如,在组件A中订阅了一个名字为 foo 的事件:

this.$bus.$on('foo', (msg) => {
  console.log(msg)
})

在组件B中触发了同名的 foo 事件:

this.$bus.$emit('foo', 'this is message from component B')

这样就会在组件A的控制台中输出 this is message from component B

使用事件总线进行方法的调用

除了可以进行事件的发布和订阅外,我们还可以使用 $bus.$emit() 方法来进行方法的调用。这种方法调用方式也被称为函数调用。

在组件A中定义一个 handleClick() 方法:

methods: {
  handleClick(msg) {
    console.log(msg)
  }
}

在组件B中使用 $bus.$emit() 方法调用组件A中的 handleClick() 方法:

this.$bus.$emit('handleClick', 'this is a test message')

这样就会在组件A的控制台中输出 this is a test message

Utilisez le bus d'événements pour publier et vous abonner à des événements

Ensuite, nous pouvons utiliser l'objet $bus pour publier et vous abonner à des événements. Nous pouvons utiliser la méthode $bus.$on() dans le composant qui doit s'abonner à l'événement pour s'abonner à l'événement. Lorsque l'événement est déclenché, la fonction de rappel sera exécutée.

Par exemple, un événement nommé foo est abonné dans le composant A : 🎜rrreee🎜L'événement foo du même nom est déclenché dans le composant B : 🎜rrreee🎜This voici comment cela fonctionne ce message du composant B sera affiché dans la console du composant A. 🎜🎜Utilisez le bus d'événements pour appeler des méthodes🎜🎜En plus de publier et d'abonner des événements, nous pouvons également utiliser la méthode $bus.$emit() pour appeler des méthodes. Cette méthode d’appel de méthode est également appelée appel de fonction. 🎜🎜Définissez une méthode handleClick() dans le composant A : 🎜rrreee🎜Utilisez la méthode $bus.$emit() dans le composant B pour appeler dans le composant A Méthode >handleClick() : 🎜rrreee🎜Cela affichera ceci est un message de test dans la console du composant A. 🎜🎜Résumé : 🎜🎜En utilisant le bus d'événements, nous pouvons facilement publier et souscrire des événements, et appeler des méthodes entre les composants Vue. Le bus d'événements propose un large éventail de scénarios d'application dans le développement de Vue et peut nous aider à mieux organiser et gérer la communication entre les composants. 🎜

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!

Déclaration:
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