Passage entre les composants Vue1.0
Utilisez $on() pour écouter les événements ; 🎜> Utilisez $emit() pour déclencher des événements dessus ;
Utilisez $dispatch() pour distribuer des événements, qui bouillonnent le long de la chaîne parent
Utilisez $broadcast() pour diffuser des événements, et les événements sont propagés vers le bas ; à tous les descendants
1. Passage de la valeur du composant enfant au composant parent :
Enfant .vue
<template> <p class="child"> <h1>子组件</h1> <button v-on:click="childToParent">想父组件传值</button> </p> </template> <script> export default{ name: 'child', data(){ return {} }, methods: { childToParent(){ this.$emit("childToParentMsg", "子组件向父组件传值"); } } } </script>parent.vue
<template> <p class="parent"> <h1>父组件</h1> <Child v-on:childToParentMsg="showChildToParentMsg" ></Child> </p> </template> <script> import Child from './child/Child.vue' export default{ name:"parent", data(){ return { } }, methods: { showChildToParentMsg:function(data){ alert("父组件显示信息:"+data) } }, components: {Child} } </script>
2. Le composant parent transmet la valeur au composant enfant
parent .vue
<template> <p class="parent"> <h1>父组件</h1> <Child v-bind:parentToChild="parentMsg"></Child> </p> </template> <script> import Child from './child/Child.vue' export default{ name:"parent", data(){ return { parentMsg:'父组件向子组件传值' } }, components: {Child} } </script>
enfant.vue
<template> <p class="child"> <h1>子组件</h1> <span>子组件显示信息:{{parentToChild}}</span><br> </p> </template> <script> export default{ name: 'child', data(){ return {} }, props:["parentToChild"] } </script>
3. Utilisez le passage de valeur eventBus.js --- le passage de valeur entre les composants frères
eventBus.js
import Vue from 'Vue' export default new Vue()
App.vue
<template> <p id="app"> <secondChild></secondChild> <firstChild></firstChild> </p> </template> <script> import FirstChild from './components/FirstChild' import SecondChild from './components/SecondChild' export default { name: 'app', components: { FirstChild, SecondChild, } } </script>
FirstChild.vue
<template> <p class="firstChild"> <input type="text" placeholder="请输入文字" v-model="message"> <button @click="showMessage">向组件传值</button> <br> <span>{{message}}</span> </p> </template> <script> import bus from '../assets/eventBus'; export default{ name: 'firstChild', data () { return { message: '你好' } }, methods: { showMessage () { alert(this.message) bus.$emit('userDefinedEvent', this.message);//传值 } } } </script>
SecondChild.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!