Maison > interface Web > js tutoriel > le corps du texte

Comment implémenter le composant parent, cliquez pour déclencher l'événement du composant enfant dans vue

亚连
Libérer: 2018-06-07 11:27:21
original
5713 Les gens l'ont consulté

Ci-dessous, je vais partager avec vous un exemple de la façon dont un clic sur un composant parent Vue déclenche un événement de composant enfant. Il a une bonne valeur de référence et j'espère qu'il sera utile à tout le monde.

Récemment, j'ai découvert les problèmes de communication entre les composants parent et enfant de Vue. Il m'est arrivé de rencontrer un événement d'envoi et de réception entre le père et l'enfant. Je vais l'enregistrer ici. 🎜> pour le composant enfant. Enregistrez les informations de citation.

Le site officiel

explique ceci : ref est utilisé pour enregistrer des informations de référence pour des éléments ou des sous-composants. Les informations de référence seront enregistrées sur l'objet $refs du composant parent. Si elle est utilisée sur un élément DOM normal, la référence pointe vers l'élément DOM ; si elle est utilisée sur un composant enfant, la référence pointe vers l'instance du composant :

Composant parent app.vue

Sous-composant popup.vue
<template>
  <p id="app">
  <!--父组件-->
  <input v-model="msg">
  <button v-on:click="notify">广播事件</button>
  <!--子组件-->
  <popup ref="child" ></popup>
  </p>
 </template>
 <script>
  import popup from &#39;@/components/popup&#39;
  export default {
  name: &#39;app&#39;,
  data: function () {
   return {
   msg: &#39;&#39;
   }
  },
  components: {
   popup
  },
  methods: {
   notify: function () {
   if (this.msg.trim()) {
    this.$refs.child.parentMsg(this.msg)
   }
   }
  }
  }
 </script>
 <style>
  #app {
  font-family: &#39;Avenir&#39;, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
  }
 </style>
Copier après la connexion

J'interprète cet exemple en plusieurs étapes :
<template>
   <p>
   <ul>
    <li v-for="item in messages">父组件输入了:{{item}}</li>
   </ul>
   </p>
  </template>
  <style>
   body {
    background-color: #ffffff;
   }
  </style>
  <script>
  export default{
   name: &#39;popup&#39;,
   data: function () {
   return {
    messages: []
   }
   },
   methods: {
   parentMsg: function (msg) {
    this.messages.push(msg)
   }
   }
  }
  </script>
Copier après la connexion

1. Lier l'élément bouton du composant parent. Définissez l'événement click, qui pointe vers la méthode notify

2. Enregistrez un ref="child"

pour le composant enfant 3. Lors du traitement de la méthode notify du composant parent, $. refs est utilisé. L'enfant transmet l'événement à la méthode parentMsg du composant enfant et transporte également le paramètre msg dans le composant parent

4. Une fois que le composant enfant a reçu l'événement du composant parent, il appelle la méthode parentMsg et place le msg reçu dans Les résultats de

dans le tableau de messages sont les suivants :

Ce qui précède est ce que j'ai compilé pour tout le monde. J'espère que cela sera utile à tout le monde à l'avenir.

Articles connexes :

Implémentation du contrôle des autorisations utilisateur dans Vue2.0

Explication détaillée de la façon d'implémenter Vuex (tutoriel détaillé)

Paiement WeChat via vue.js

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
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!