这么一种情况: 组件需要判断是否注册事件来走下一步。在vue2中this.$listeners就可以获取到相应事件,而在vue3中,就行不通了。
需求
如何在Vue3中获取到this.$listeners['custom-click']
方法
custom-click需要在emits注册,不然会发出vue 警告
emits: ['custom-click'],
复制代码
- Vue3 移除$listeners

emits也无法访问

- Vue3在emit事件检查
emits时,也会检查props的onXXXX属性
所以在props注册
props{
onCustom-click: Function
// props采用小驼峰,横线需保留
}
复制代码
-
this['onCustom-click']直接访问,emits里的可以保留,不然vscode volar插件会报错 -
props用小驼峰,所以
custom-click改为customClick
参考
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END























![[桜井宁宁]COS和泉纱雾超可爱写真福利集-一一网](https://www.proyy.com/skycj/data/images/2020-12-13/4d3cf227a85d7e79f5d6b4efb6bde3e8.jpg)

![[桜井宁宁] 爆乳奶牛少女cos写真-一一网](https://www.proyy.com/skycj/data/images/2020-12-13/d40483e126fcf567894e89c65eaca655.jpg)