vue组件之间的通信

7、vue 组件之间的通信
提示:
  • 情况一:组件很多,且通信复杂 => 建议使用vuex;
  • 情况二:组件不多 => 建议使用事件触发$emit 和监听 $on;
主要介绍情况二:
7.1 兄弟组件(或者 完全不相关的组件)
创建事件中心(即new vue())
let Hub = new Vue();
组件1:触发
Hub.$emit('myClick'[, param ...]);
组件2:监听
Hub.$on('myClick', (param) => {console.log(param)});

7.2 父子组件
事件
子组件触发父组件中的事件
子组件child 触发:
let vm = this;
vm.$emit("myClick"[, param ...]); 或者 vm.$emit("my-click"[, param ...]);
父组件parent 监听:
<child @myClick="handleClick"></child>
handleClick(param1) {console.log(param)}; // 接收参数param1

父组件调用子组件中的事件
<child ref="child"></child>
callChildEvent() {
let vm = this;
vm.$refs.child.childEvent();
}

数据
父组件调用子组件数据
<child ref="child"></child>
callChildEvent() {
let vm = this;
vm.$refs.child.childData;
}

父组件向子组件传递数据
父:<child :pass-data="passData"></child>
子:三种方式接收数据
A1:props: ['passData']
A2:props: {passData: String} // 需要制定类型
A3:props: {passData: {type: String, default: '123'}} // 需要制定默认值


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值