Vue3:组件间通信-自定义事件方式

一、情景说明

自定义事件常用于:子 => 父。
注意区分:原生事件、自定义事件。

  • 原生事件:
    • 事件名是特定的(clickmosueenter等等)
    • 事件对象$event: 是包含事件相关信息的对象(pageXpageYtargetkeyCode
  • 自定义事件:
    • 事件名是任意名称
    • 事件对象$event: 是调用emit时所提供的数据,可以是任意类型!!!

在我看来,通过自定义事件实现子传父的效果,就类似上一篇,通过props方式,实现子传父的效果和代码复杂度相同。

区别:
props方式,是父给子传一个函数,供子组件调用。
自定义事件方式,是父给子传一个自定义事件,供子组件调用。

二、案例

1、父组件
给子组件Child绑定事件,事件名是:send-toy

<Child @send-toy="saveToy"/>

给事件编写对应的函数:saveToy

	function saveToy(value:string){
		console.log('saveToy',value)
		toy.value = value
	}

2、子组件
声明父组件传递的事件

	const emit =  defineEmits(['send-toy'])

触发父组件提供的事件
emit(事件名,参数)

<button @click="emit('send-toy',toy)">测试</button>
  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值