兄弟组件传值

兄弟组件传值

第一种:eventBus

新建一个js文件, 我这里叫做 bus.js;

文件内容:

      import Vue from 'vue';  

     export default new Vue();

然后在你需要触发的 组件中引入 import bus from ‘文件路径’

     执行:bus.$emit('触发名称', 传输的数据 )

最后在你需要的通信的另一个组件中 mounted生命周期钩子中执行如下:

bus.$on('触发名称', res => {

//写你需要的方法

})

在这里插入图片描述

第二种:直接在 main.js中 直接如下

然后其中一个兄弟组件 执行

this. r o o t . v m . root.vm. root.vm.emit(‘触发名称’, 传输的数据);

另一个兄弟组件中执行

this. r o o t . v m . root.vm. root.vm.on(‘触发名称’, 传输的数据);

第三种:同样是直接在 main.js

注意:emit 和 on 中 第一参数 触发名称 必须相同,同时二者原理一致

同时,需要关闭该通信,尤其是接口调用的时候,关闭方法 this.**.$off(“通信名称”)
在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值