Vue2 组件间通讯全方案

说的不对的,敬请谅解,你们共同讨论进步vue

组件通信包括:父子组件间的通讯和兄弟组件间的通讯。在组件化系统构建中,组件间通讯必不可少的。函数

父组件--> 子组件

1. 属性设置

父组件关键代码以下:组件化

<template>
    <Child :child-msg="msg"></Child>
</template>

子组件关键代码以下:this

export default {
  name: 'child',
  props: {
    child-msg: String
  }
};

child-msg 为父组件给子组件设置的额外属性值,属性值需在子组件中设置props,子组件中可直接使用child-msg变量。spa

2. 子组件调用父组件

子组件经过 $parent 得到父组件,经过 $root 得到最上层的组件。code

子组件--> 父组件

1. 发送事件/监听事件

子组件中某函数内发送事件:component

this.$emit('toparentevent', 'data');

父组件监听事件:blog

<Child :msg="msg" @toparentevent="todo()"></Child>

toparentevent 为子组件自定义发送事件名称,父组件中@toparentevent为监听事件,todo为父组件处理方法。事件

2. 父组件直接获取子组件属性或方法

给要调用的子组件起个名字。将名字设置为子组件 ref 属性的值。ip

<!-- 子组件。 ref的值是组件引用的名称 -->
<child-component ref="aName"></child-component>

父组件中经过 $refs.组件名 来得到子组件,也就能够调用子组件的属性和方法了。

var child = this.$refs.aName
child.属性
child.方法()

父组件经过 $children 能够得到全部直接子组件(父组件的子组件的子组件不是直接子组件)。须要注意 $children 并不保证顺序,也不是响应式的。

Bus中央通讯

目前中央通讯是解决兄弟间通讯,祖父祖孙间通讯的最佳方法,不只限于此,也能够解决父组件子组件间的相互通讯。以下图:

clipboard.png

各组件可本身定义好组件内接收外部组件的消息事件便可,不用理会是哪一个组件发过来;而对于发送事件的组件,亦不用理会这个事件到底怎么发送给我须要发送的组件。

先设置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中央通讯的方案各类状况下均可用,比较方便,具体内在原理后续更新说明。

相关文章
相关标签/搜索