若是在你项目中须要多处用到同级组件通信,而又不想去写繁琐的vuex,能够参考这个小思路。本人在写项目中琢磨出来的,感受挺好用,分享一下。vue
1.在utils文件夹下添加BusEvent.jsvuex
注释已经很详细了,也很简单,再也不过多阐述。服务器
import Vue from "vue"; const Bus = new Vue(); /** * 同级组件通信,提交事件 * @param {String} component 要提交的目标组件名称 * @param {string} action 要调用目标组件的方法名 * @param {any} param 目标组件的方法参数 */ export const BusEmit = (component, action, param) => { Bus.$emit(component, action, param); }; /** * 同级组件通信,监听销毁事件 */ export const BusOn = { mounted() { Bus.$on(`${this.$options.name}`, this.onBusAction); }, beforeDestroy() { Bus.$off(`${this.$options.name}`, this.onBusAction); }, methods: { onBusAction(action, param) { log(`调用组件:${this.$options.name},方法:${action},参数:${param}`); this[action](param); } } };
2.须要监听事件的组件app
引入 BusOn 挂载在组件的mixins上。函数
import { BusOn} from "@/utils/BusEvent"; export default { name: "app", mixins: [BusOn], methods: { show(is){ console.log(is); } }
3.发起通信的组件this
引入 BusEmit 发起同级组件通信。code
import { BusEmit} from "@/utils/BusEvent"; export default { name: "child", methods: { emitShow(is){ //大概意思:我要调用 app 组件的 show 方法,而且传了一个 true 的参数 BusEmit("app","show",true) } }
好处:component
好比:在 htttp.js事件
省略了若干代码,定义了一个处理报错信息的函数。string
import { BusEmit } from "../utils/event-bus"; ** * 请求失败后的错误统一处理 * * @param {Number} status 请求失败的状态码 */ const errorHandle = err => { //....省略 BusEmit("app","toast",{ text:'链接到服务器失败', time:1000, }) }
固然你能够在 BusEvent.js 进行更多的封装,或者你有更好的思路,欢迎分享讨论。