Maison interface Web Voir.js Six façons de communiquer entre les composants Vue

Six façons de communiquer entre les composants Vue

Jun 11, 2023 pm 08:42 PM
vue组件通信 props传参 事件总线。

Vue 是一个流行的 JavaScript 框架,用于构建单页应用程序。在 Vue 中,组件是构建应用程序的基本单位,组件是用于显示和处理数据的可复用代码块。组件通信是组件之间数据传递和交互的核心机制之一。在本文中,我们将探讨六种组件通信方式。

一、Props 和 Events

Props 和 Events 是 Vue 中最基本的组件通信方式。通过 props,父组件向子组件传递数据。而子组件通过 events 构造函数向父组件发送数据。这种通信方式的特点是单向传递。

父组件通过 props 将数据传递给子组件:

<template>
  <child-component :message="parentMessage"></child-component>
</template>
<script>
  import ChildComponent from './ChildComponent.vue'
  export default {
    data() {
      return {
        parentMessage: 'this is parent'
      }
    },
    components: {
      ChildComponent
    }
  }
</script>
Copier après la connexion

在子组件中,需要声明 props,并使用 props 接收来自父组件的数据:

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

然后,子组件通过 events 发送数据给父组件:

<template>
  <button @click="updateParentMessage">Update Parent Message</button>
</template>
<script>
  export default {
    methods: {
      updateParentMessage() {
        this.$emit('update-message', 'this is child');
      }
    }
  }
</script>
Copier après la connexion

在父组件中,需要为子组件监听 events,在事件监听函数中接收来自子组件的数据:

<template>
  <child-component :message="parentMessage" @update-message="updateMessage"></child-component>
</template>
<script>
  import ChildComponent from './ChildComponent.vue'
  export default {
    data() {
      return {
        parentMessage: 'this is parent'
      }
    },
    components: {
      ChildComponent
    },
    methods: {
      updateMessage(message) {
        this.parentMessage = message;
      }
    }
  }
</script>
Copier après la connexion

二、Vuex

Vuex 是 Vue 中用于状态管理的一个官方插件。Vuex 实现了一个全局的状态管理模式。它通过 store 集中管理应用程序的所有组件的状态。当多个组件共享状态时,使用 Vuex 可以更方便地管理组件之间的数据交换和通信。

首先,我们需要创建一个 Vuex store:

import Vuex from 'vuex'
import Vue from 'vue'

Vue.use(Vuex)

const store = new Vuex.Store({
  state: {
    message: 'hello world'
  },
  mutations: {
    updateMessage(state, message) {
      state.message = message
    }
  },
  actions: {
    updateMessage({ commit }, message) {
      commit('updateMessage', message)
    }
  },
  getters: {
    getMessage: state => state.message
  }
})

export default store
Copier après la connexion

在组件中,我们可以使用 $store 访问 store 中的状态,使用 commit 方法来提交 mutations 来修改状态:

<template>
  <div>{{ this.$store.getters.getMessage }}</div>
  <button @click="updateMessage">Update Message</button>
</template>
<script>
  export default {
    methods: {
      updateMessage() {
        this.$store.dispatch('updateMessage', 'hello vuex')
      }
    }
  }
</script>
Copier après la connexion

三、$parent 和 $children

Vue 中的每个组件都具有 $parent 和 $children 属性。$parent 属性指向组件的父组件,$children 属性指向组件的子组件。通过 $parent 和 $children 属性,组件可以直接访问父组件和子组件的数据和方法。

例如,父组件可以通过 $children 属性访问子组件的数据和方法:

<template>
  <div>
    {{ $children[0].message }}
    <button @click="$children[0].updateMessage">Update message</button>
  </div>
</template>
Copier après la connexion

在子组件中,需要定义 message 和 updateMessage 方法:

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

四、$refs

Vue 中的每个组件都具有 $refs 属性。$refs 属性是一个对象,包含了在组件中使用 ref 属性命名的子组件或 DOM 元素的引用。通过 $refs 属性,组件之间可以相互引用和调用。

例如,我们可以在父组件中通过 ref 属性获取子组件的引用:

<template>
  <div>
    <child-component ref="childComponent"></child-component>
    <button @click="updateMessage">Update message</button>
  </div>
</template>
<script>
  import ChildComponent from './ChildComponent.vue'
  export default {
    components: {
      ChildComponent
    },
    methods: {
      updateMessage() {
        this.$refs.childComponent.updateMessage()
      }
    }
  }
</script>
Copier après la connexion

在子组件中,我们需要定义 updateMessage 方法:

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

五、Event Bus

Event Bus 是一种广泛使用的中央事件系统,可以在 Vue 组件之间有效地传递事件。Event Bus 是一个简单的 Vue 实例,可以通过 $emit 方法向其他 Vue 组件发送事件,也可以通过 $on 方法接收其他 Vue 组件发送的事件。

在实现 Event Bus 时,我们需要创建一个新的 Vue 实例:

import Vue from 'vue'

const bus = new Vue()

export default bus
Copier après la connexion

然后,我们可以在组件中引入 Event Bus 并使用 $emit 发送事件,使用 $on 接收事件:

// 发送事件
import Bus from './Bus.js'

Bus.$emit('event-name', data)

// 接收事件
import Bus from './Bus.js'

Bus.$on('event-name', (data) => {
  console.log(data)
})
Copier après la connexion

六、Provide 和 Inject

Vue 2.2 中新增的 Provide 和 Inject 是一种高级的组件通信方式。Provide 和 Inject 允许父组件将数据传递给所有后代组件,而不是只传递给直接子组件。Provide 和 Inject 是一种不同于 props、events 和 $parent/$children 的组件通信形式,是一种更加灵活和封装性更强的通信方式。

父组件通过 provide 提供数据:

<template>
  <child-component></child-component>
</template>
<script>
  export default {
    provide: {
      message: 'hello provide'
    }
  }
</script>
Copier après la connexion

在子组件中,我们需要定义 inject 接收父组件传递的数据:

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

这就是六种 Vue 组件通信方式的介绍。不同的应用场景需要采用不同的组件通信方式。掌握这些通信方式可以使 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!

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Communication des composants Vue : utilisation des fonctions de rappel pour la communication des composants Communication des composants Vue : utilisation des fonctions de rappel pour la communication des composants Jul 09, 2023 pm 07:42 PM

Communication des composants Vue : utilisation des fonctions de rappel pour la communication des composants Dans les applications Vue, nous devons parfois laisser différents composants communiquer entre eux afin qu'ils puissent partager des informations et collaborer les uns avec les autres. Vue propose diverses façons d'implémenter la communication entre les composants, l'une des méthodes les plus courantes consiste à utiliser des fonctions de rappel. Une fonction de rappel est un mécanisme dans lequel une fonction est passée en argument à une autre fonction et est appelée lorsqu'un événement spécifique se produit. Dans Vue, nous pouvons utiliser des fonctions de rappel pour implémenter la communication entre les composants, afin qu'un composant puisse

Communication des composants Vue : utilisez la directive v-cloak pour initialiser la communication d'affichage Communication des composants Vue : utilisez la directive v-cloak pour initialiser la communication d'affichage Jul 09, 2023 pm 08:10 PM

Communication des composants Vue : utilisez la directive v-cloak pour initialiser la communication d'affichage Dans le développement de Vue, la communication des composants est un sujet très important. Vue fournit une variété de méthodes de communication, parmi lesquelles l'utilisation de la directive v-cloak pour initialiser la communication d'affichage est une méthode courante. Dans cet article, nous apprendrons comment utiliser les directives v-cloak pour la communication entre les composants et l'expliquerons en détail avec des exemples de code. Tout d’abord, comprenons ce que fait l’instruction v-cloak. La directive v-cloak est un Vu

Communication des composants Vue : utilisation de $on pour l'écoute d'événements personnalisés Communication des composants Vue : utilisation de $on pour l'écoute d'événements personnalisés Jul 08, 2023 pm 01:37 PM

Communication des composants Vue : utilisez $on pour une écoute d'événements personnalisée. Dans Vue, les composants sont indépendants et chaque composant a son propre cycle de vie et ses propres données. Cependant, dans le processus de développement lui-même, la communication entre les composants est inévitable. Vue fournit un moyen très flexible et efficace de communication entre composants : l'écoute d'événements personnalisés. Le mécanisme d'écoute d'événements personnalisé de Vue est implémenté sur la base du modèle de publication-abonnement. Vous pouvez écouter un événement personnalisé dans un composant en utilisant la méthode $on de l'instance Vue et utiliser la méthode $emit dans

Communication des composants Vue : utilisez la directive v-model pour la communication de liaison bidirectionnelle Communication des composants Vue : utilisez la directive v-model pour la communication de liaison bidirectionnelle Jul 07, 2023 pm 03:03 PM

Communication des composants Vue : utilisez la directive v-model pour la communication de liaison bidirectionnelle. Vue.js est un framework JavaScript progressif permettant de créer des interfaces utilisateur légères, flexibles et efficaces. Dans les applications Vue, la communication entre les composants est une fonctionnalité très importante. Vue propose diverses façons d'implémenter la communication entre les composants, parmi lesquelles l'utilisation de la directive v-model pour la communication par liaison bidirectionnelle est un moyen courant et pratique. Dans Vue, la directive v-model est utilisée dans les formulaires

Communication des composants Vue : utilisation de $watch pour la surveillance des données Communication des composants Vue : utilisation de $watch pour la surveillance des données Jul 07, 2023 am 11:09 AM

Communication entre composants Vue : utilisation de $watch pour la surveillance des données Dans le développement de Vue, la communication entre composants est une exigence courante. Vue propose diverses façons d'implémenter la communication entre les composants. L'une des méthodes les plus courantes consiste à utiliser $watch pour la surveillance des données. Cet article présentera l'utilisation de $watch et donnera des exemples de code correspondants. L'objet instance de Vue fournit la méthode $watch pour surveiller les modifications des données. $watch accepte deux paramètres : le nom de la propriété des données à surveiller et la fonction de rappel. Lors de l'écoute de données

Modèles de conception pour la communication entre les composants Vue.js Modèles de conception pour la communication entre les composants Vue.js Sep 02, 2023 am 11:45 AM

En tant que développeurs, nous souhaitons produire un code gérable et maintenable, qui est également plus facile à déboguer et à tester. Pour y parvenir, nous utilisons les meilleures pratiques appelées modèles. Les modèles sont des algorithmes et des architectures éprouvés qui nous aident à accomplir des tâches spécifiques de manière efficace et prévisible. Dans ce didacticiel, nous examinerons les modèles de communication des composants Vue.js les plus courants, ainsi que certains pièges que nous devrions éviter. Nous savons tous que dans la vraie vie, il n’existe pas de solution unique à tous les problèmes. De même, dans le développement d’applications Vue.js, il n’existe pas de modèle universel s’appliquant à tous les scénarios de programmation. Chaque mode présente ses propres avantages et inconvénients et convient à des cas d'utilisation spécifiques. La chose la plus importante pour les développeurs Vue.js est

Communication des composants Vue : utilisez la directive v-bind pour le transfert de données Communication des composants Vue : utilisez la directive v-bind pour le transfert de données Jul 07, 2023 pm 04:46 PM

Communication avec les composants Vue : utilisez l'instruction v-bind pour le transfert de données. Vue.js est un framework frontal populaire qui offre de puissantes capacités de développement de composants. Dans les applications Vue, la communication des composants est un problème important. L'instruction v-bind est une méthode de transfert de données fournie par le framework Vue. Cet article explique comment utiliser l'instruction v-bind pour transférer des données entre composants. Dans Vue, la communication entre composants peut être divisée en deux situations : la communication entre composants parent-enfant et la communication entre composants frères et sœurs. Ci-dessous, nous présenterons respectivement ces deux aspects.

Six façons de communiquer entre les composants Vue Six façons de communiquer entre les composants Vue Jun 11, 2023 pm 08:42 PM

Vue est un framework JavaScript populaire pour créer des applications monopage. Dans Vue, les composants constituent l'unité de base pour la création d'applications. Les composants sont des blocs de code réutilisables utilisés pour afficher et traiter les données. La communication entre les composants est l'un des principaux mécanismes de transfert de données et d'interaction entre les composants. Dans cet article, nous explorerons six manières par lesquelles les composants communiquent. 1. Accessoires et événements Les accessoires et événements sont les méthodes de communication des composants les plus élémentaires dans Vue. Grâce aux accessoires,

See all articles