Vue自定义组件使用事件修饰符的踩坑记录

2022-04-15 0 1,073

前言

今天在使用自写组件时,突然遇到久违的冒泡事件,就想着使用Vue自带的事件修饰符(.stop),本以为可以就此解决冒泡,却遇到这个问题。

Vue自定义组件使用事件修饰符的踩坑记录

脑中一片问号????这是什么鬼,我是按照Vue文档写的啊(吐血)

于是,我开始踏上了解决错误的路程

程序员常规操作:

打开浏览器–百度/谷歌搜一搜,发现搜出来的东西不少,没一个是能解决我的问题的答案,没办法Vue文档走起!!!!
看了至少几十遍Vue文档的我,自以为没有看漏什么东西,确信Vue文档也没有解决这种问题的答案,苦苦寻找,来到这里

Vue自定义组件使用事件修饰符的踩坑记录

嗯?这个event.stopPropagation()???

顿时灵光一现!!!!

Vue自定义组件使用事件修饰符的踩坑记录

既然是event.stopPropagation()可以触发,那我把event传递过去,问题是不是就可以解决了。说干就干!!

开始素人 代码修改

Vue自定义组件使用事件修饰符的踩坑记录

使用自定义组件如下:

Vue自定义组件使用事件修饰符的踩坑记录

来看看控制台输出

Vue自定义组件使用事件修饰符的踩坑记录

可以了!!!!!可是,为什么会输出两次呢????本想着解决就行了,但是,奇怪的好奇心出来了。

开始踏上寻找触发两次BUG的路程

尝试加上.once修饰符,发现无效,多点几下,发现都是触发两次

Vue自定义组件使用事件修饰符的踩坑记录

奇奇怪怪的!这是什么鬼啊!!!!

继续尝试使用Vue事件修饰符.once,出现了如下输出

Vue自定义组件使用事件修饰符的踩坑记录

确实是可以只触发一次了,可是第一次为什么会蹦出来两次打印啊!!!(晕)

问题没有完全解决,继续找。。。。

查看打印时间戳(timeStamp),都是同一时间触发,这可不好弄啊

继续使用浏览器搜索

灵感来了,用setTimeout强制只能触发一次怎么样?

开始代码改造

Vue自定义组件使用事件修饰符的踩坑记录

好了,看看效果

Vue自定义组件使用事件修饰符的踩坑记录

成功!!!!一路坎坷的解决了!!!

总结

到此这篇关于Vue自定义组件使用事件修饰符的文章就介绍到这了,更多相关Vue使用事件修饰符内容请搜索NICE源码以前的文章或继续浏览下面的相关文章希望大家以后多多支持NICE源码!

免责声明:
1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

NICE源码网 JavaScript Vue自定义组件使用事件修饰符的踩坑记录 https://www.niceym.com/27769.html