vue兄弟组件间的通信(事件总线)

一、场景描述

导航栏与地图展示区为两个兄弟组件,导航栏组件用到的所有数据都来源于地图区组件通过导航栏按钮切换,控制地图区域数据的变化
在这里插入图片描述

二、实现步骤

1. 首先两个组件中都引入全局事件总线

import eventBus from "@/utils/eventBus";

eventBus.js中代码:(new一个组件作为中间仓库)

import Vue from 'vue'
export default new Vue()

2. 两个组件的代码

导航栏组件的代码【发送信息】

handleClick() {
eventBus.$emit ('一个相同的名字', ' parameter')
}

地图区组件绑定的代码(写在created中)

created() {
eventBus.$on("一个相同的名字", (parameter) => {
// 写入所用到的事件,例如加载地图、改变图表
this.currentLayer = " parameter "; //来自地图区域数据来源区所用到的参数
this.loadMapData();});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值