Vue3|Vue3 $emit用法指南(含选项API、组合API及 setup 语法糖)
目录
- Vue Emit是如何工作的?
- 选项API - this.$emit
- 带有setup()的组合API - context.emit
- 在
count += i" /> Count: {{ count }}
每次我们点击按钮,Child.vue
都会 emit 一个add
事件,并带有一个0到1之间的随机值。 然后,Parent.vue
捕捉到这个事件,并将这个值添加到计数中。
可以传递任意多的参数,监听器也会收到所有的参数:
- Child -
$emit('add', Math.random(), 44, 50)
- Parent -
@add="(i, j, k) => count += i + j + k"
script
中 emit 一个事件会更好。特别是当我们想在 emit 事件之前执行一些逻辑时,这很有用。
在Vue 3中,我们有2种不同的方法来做到这一点:
- 选项API -
this.$emit
- 带有
setup()
的组合API -context.emit
- 带有
在 Parent.vue 中接收:
带有setup()的组合API - context.emit 在 组合API中,如果使用setup
函数,就不能在用this
,也就是不能调用this.$emit()
方法了。
相反,可以使用 setup 方法中的第二个参数context
来访问emit
方法。我们可以用之前使用的事件名称和值调用context.emit
。
MyTextInput.vue
在
然而,如果我们传递一个对象,我们可以为每个事件添加一个验证器函数,我们可以在里面检查值是否是我们所需要的格式。
像事件监听器一样,验证器接受我们传入所有参数。
这与prop validation 类似,如果我们的验证器返回false
,会在控制台得到一个警告,这为我们提供了一些有用的信息。
MyTextInput.vue
最佳实践
使用 emits 定义自定义事件
如果我们不使用defineEmits
,我们仍然可以通过export default
中定义emits
选项来跟踪一个组件的自定义事件。
这对保持良好的组件文档很重要,如果我们试图使用一个没有在 emits 中声明的事件,也会从Vue那里得到错误。
当在 emits 选项中定义了原生事件 (如 change) 时,将使用组件中的事件替代原生事件侦听器。
【Vue3|Vue3 $emit用法指南(含选项API、组合API及 setup 语法糖)】
正确的事件命令
在 vue3 中,与组件和 prop 一样,事件名提供了自动的大小写转换。如果在子组件中触发一个以 camelCase (驼峰式命名) 命名的事件,你将可以在父组件中添加一个 kebab-case (短横线分隔命名) 的监听器。
然而,如果你使用的是Vue 2,事件名称没有自动的大小写转换,由于v-on
指令会自动将你的事件名称转换为小写,所以camelCase命名的事件不可能被监听到。
例如,如果我们发出了一个名为myEvent
的事件,监听my-event
将无法工作。
到此这篇关于Vue3 $emit用法指南的文章就介绍到这了,更多相关Vue3 $emit指南内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- vue3.x使用swiper实现卡片轮播
- MTCNN优化和另类用法
- 【vue3源码】五、watch源码解析
- cat和find 的用法
- 不为人知的排序和筛选的高级用法!
- ldr 特殊用法
- C语言深入探索之单链表与typedef的用法
- vue3的diff算法
- C#线程委托BeginInvoke与EndInvoke的用法
- vue3|vue3学习7(props以及验证)
- Child -