大家或许都听说EventBus,或者说或多或少都了解过,他可以在任何两个组件中进行传值,不局限于父子、祖孙或是兄弟组件,也可以说他是一种发布——订阅的设计模式。
我将使用拆分为五个步骤:创建、引入、监听、递交、销毁
1、创建
// 创建一个EventBus.js文件
// 引入
import Vue from 'vue'
// 创建实例
vueconst EventBus = new Vue()
// 导出
export default EventBus
2、 引入 有两种方法
1. 使用import引入
import EventBus from '../EventBus'
2.使用Vue原型链引入
// 在 src 的 main.js 中,加上以下代码
// 引入第一步创建好的 EventBus
import EventBus from './EventBus'
// 这个方式可以在任何组件里直接用 this.$EventBus 调用
Vue.prototype.$EventBus = EventBus
// 也可以直接这样使用,不需要第一步的创建
import Vue from 'vue'
Vue.prototype.$EventBus = new Vue()
3、监听
要使用监听方法