vue3中emit的声明触发事件

1.emit有什么用

vue3子组件调父组件的方法(就是用props把父方法传给子,即父传子,只不过传的是方法)

1.1父引用子

父组件中把方法作为属性传入子组件,在子组件里直接调用这个方法(写在setup()方法里)

在这边创建了一个按钮,里面加上一个点击事件@click 在事件的里面写上emit方法

“add” 是名称 “123”是值

在这边就可以直接用@《名称》=“方法名” 

这样就可以将add里面的内容赋给onAdd这个方法了

现在来看看效果

每次点击一次按钮,在控制台中都会多一个“123”,所以代表传值成功了

此时可以对他升级,在这边传递一个随机数

定义一个num变量,在下面的方法中对他进行赋值,并且每次都在控制台输出

最后再放到页面中显示

最后的效果就会变成这样了

1.2 传递多个对象

只需在之前的代码中加上一个对象,并且将原来的传值方式变为数组

那么现在就可以传递多个

        

这边也同样和之前一样,只需要再多加一个对象的调用就可以啦

现在就可以看到,控制台和页面中都输出了想要的结果

这样就实现了多个对象传递的方法

Vue3,emit被用于子组件向父组件传递事件。通过定义emits属性,可以指定子组件可以触发的事件名称。例如,在子组件,可以使用ctx.emit来触发指定的事件,并传递参数。父组件可以通过定义同名的方法来接收子组件传递的参数。这样就实现了子组件向父组件传值的功能。在使用emit时,需要注意以下几点: 1. 在子组件定义emits属性来指定事件名称。 2. 在子组件的setup函数使用ctx.emit触发指定的事件,并传递参数。 3. 在父组件定义同名的方法来接收子组件传递的参数。这样,就可以实现子组件向父组件传值的功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [【vue3】vue3 setup如何使用emit?](https://blog.csdn.net/qq_39576711/article/details/123480701)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [vue3emit使用方法(新)](https://blog.csdn.net/yun_shuo/article/details/120308142)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值