vue 中组件间有哪些通信方式?————vue

本文详细介绍了Vue中8种组件通信的方式,包括props、$emit/$on、$children/$parent、$attrs/$listeners、ref、$root、eventbus以及Vuex。重点讲解了如何通过这些机制实现父子组件、兄弟组件以及全局事件的交互,并提供了实用示例,尤其是Vuex作为状态管理仓库的角色,以及如何使用eventbus实现实现无关联组件间的通信。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

vue 8种组件的通信方式

vue组件8种通讯:

    props
    $emit/$on
    $children/$parent
    $attrs/$listeners
    ref
    $root
    eventbus
    vuex

c h i l d r e n / children/ children/parent

this.$parent.xxxx()//找爸爸
this.$children.xxxx()//找儿子
这两个比较容易且常用!

使用ref特性

ref有点身份证的感觉,直接通过身份证查询对应的实例

this.$refs.childComponent  //这个是身份证为childComponent
this.$refs.childComponent.msg //这个实例下的msg参数
也常用

Vuex 状态管理

这个属于仓库了。相当于往仓库放东西,其他页面想用这个东西就自己去仓库里面拿就可以了!

e m i t / emit/ emit/on

这个就有趣了。通过一个util.js做中转站(里面没东西的)
完全没亲属关系的组件间,直接沟通

//公共方法中转站。
import Utils from './common/util.js';
    // 中转站方法调用
    Utils.$on('getMailCloudNormal', function () {
        that.getMailCloudNormal();
    })
    Utils.$on('reload', function () {
        that.reload();
    })

使用:直接调用,陌生组件直接沟通,贼方便!!!

其他组件,想用上面的话!
Utils.$emit('getMailCloudNormal'); 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值