说的不对的,敬请谅解,你们共同讨论进步vue
组件通信包括:父子组件间的通讯和兄弟组件间的通讯。在组件化系统构建中,组件间通讯必不可少的。函数
父组件关键代码以下:组件化
<template> <Child :child-msg="msg"></Child> </template>
子组件关键代码以下:this
export default { name: 'child', props: { child-msg: String } };
child-msg 为父组件给子组件设置的额外属性值,属性值需在子组件中设置props,子组件中可直接使用child-msg变量。spa
子组件经过 $parent 得到父组件,经过 $root 得到最上层的组件。code
子组件中某函数内发送事件:component
this.$emit('toparentevent', 'data');
父组件监听事件:blog
<Child :msg="msg" @toparentevent="todo()"></Child>
toparentevent 为子组件自定义发送事件名称,父组件中@toparentevent为监听事件,todo为父组件处理方法。事件
给要调用的子组件起个名字。将名字设置为子组件 ref 属性的值。ip
<!-- 子组件。 ref的值是组件引用的名称 --> <child-component ref="aName"></child-component>
父组件中经过 $refs.组件名 来得到子组件,也就能够调用子组件的属性和方法了。
var child = this.$refs.aName child.属性 child.方法()
父组件经过 $children 能够得到全部直接子组件(父组件的子组件的子组件不是直接子组件)。须要注意 $children 并不保证顺序,也不是响应式的。
目前中央通讯是解决兄弟间通讯,祖父祖孙间通讯的最佳方法,不只限于此,也能够解决父组件子组件间的相互通讯。以下图:
各组件可本身定义好组件内接收外部组件的消息事件便可,不用理会是哪一个组件发过来;而对于发送事件的组件,亦不用理会这个事件到底怎么发送给我须要发送的组件。
先设置Bus
//bus.js import Vue from 'vue' export default new Vue();
组件内监听事件:
import bus from '@/bus'; export default { name: 'childa', methods: { }, created() { bus.$on('childa-message', function(data) { console.log('I get it'); }); } };
发送事件的组件:
import bus from '@/bus'; //方法内执行下面动做 bus.$emit('childa-message', this.data);
Bus中央通讯的方案各类状况下均可用,比较方便,具体内在原理后续更新说明。