Vue2.x中的父子组件相互通信
2017-05-02 10:12
351 查看
原理
在 Vue.js 中,父子组件的关系可以总结为 props down, events up 。父组件通过 props 向下传递数据给子组件,子组件通过 events 给父组件发送消息。看看它们是怎么工作的。
业务场景
这里指的是直接父子级关系的通信
美女(子组件)将消息发送给大群(父组件)
大群(父组件)收到美女发送的消息后再回个信息给美女(子组件)
父组件
template
<template> <div> <p>群消息girl:</p> <div> {{ somebody }} 说: 我 {{ age }} 了。 </div> <hr> <v-girl-group :girls="aGirls" :noticeGirl="noticeGirl" @introduce="introduceSelf"></v-girl-group> </div> </template>
注意的点:
这里在父组件使用
v-on来监听子组件上的自定义事件($emit的变化),一旦发生变化
noticeGirl方法就会触发
<script> import vGirlGroup from './GirlGroup' export default { name: 'girl', components: { vGirlGroup }, data () { return { aGirls:[{ name:'小丽', age:22 },{ name:'小美', age:21 },{ name:'小荷', age:24 }], somebody:'', age:'', noticeGirl:'' } }, methods: { introduceSelf (opt) { this.somebody = opt.name; this.age = opt.age; // 通知girl收到消息 this.noticeGirl = opt.name + ',已收到消息'; } } } </script>
注意的点:
这里methods中定义的方法
introduceSelf就是父组件接收到子组件发出的
$emit的事件处理程序
子组件
template
<template> <div> <ul> <li v-for="(value, index) in girls"> {{ index }} - {{ value.name }} - {{ value.age }} <button @click="noticeGroup(value.name,value.age)">发送消息</button> </li> </ul> <div>接收来自大群的消息:{{ noticeGirl }}</div> </div> </template>
script
<script> export default { name: 'girl-group', props: { girls: { type: Array, required: true }, noticeGirl: { type: String, required: false } }, methods: { noticeGroup (name, age) { this.$emit('introduce',{ name: name, age: age }) } } } </script>
注意的点:
子组件使用
$emit发出自定义事件
相比于Vue1.x的变化:
$dispatch 和 $broadcast 已经被弃用
*官方推荐的通信方式
首选使用Vuex
使用事件总线:eventBus,允许组件自由交流
具体可见:https://cn.vuejs.org/v2/guide/migration.html#dispatch-和-broadcast-替换
结果
相关文章推荐
- Vue2.x中的父子组件相互通信的实现方法
- Vue2.x中的父子组件相互通信
- vue.js父子组件通信动态绑定
- vue开发:Vue 非父子组件通信方法(非Vuex)
- vue开发:vue父子组件与非父子组件之间的通信
- vue中组件之间相互通信(一)
- vue父子组件通信
- 起步 - 从场景中看父子组件间通信
- Vue之父子兄弟组件间通信
- Vue笔记2 父子组件的数据通信
- [js高手之路]Vue2.0基于vue-cli+webpack父子组件通信教程
- react初探(二)之父子组件通信、封装公共组件
- [IMWeb训练营作业]Vuejs的父子组件通信
- FLutter父子组件通信
- react 父子组件之间的通信和函数调用
- Vue父子组件之间的通信实例详解
- Vue父子组件互相通信实例
- 【QT】父组件与子组件的相互通信例子(用signal-slot实现)
- ReactJS学习笔记 父子组件间的通信
- vue2.0父子组件以及非父子组件之间通信