首页
学习
活动
专区
工具
TVP
发布

vue.js中实现阻止事件冒泡

当父子元素中都有点击事件的时候,为了让触发子元素中的事件时,不去触发父元素中的事件,可以在子元素事件中添加stop来阻止事件冒泡。....stop 是阻止冒泡行为,不让当前元素的事件继续往外触发,如阻止点击div内部事件,触发div事件 .prevent 是阻止事件本身行为,如阻止超链接的点击跳转,form表单的点击提交 .self 是只有是自己触发的自己才会执行...,如果接受到内部的冒泡事件传递信号触发,会忽略掉这个信号 .capture 是改变js默认的事件机制,默认是冒泡,capture功能是将冒泡改为倾听模式 .once 是将事件设置为只执行一次,如 .click.prevent.once...阻止click事件冒泡(防止触发另一个事件)的方法 使用vue阻止子级元素的click事件冒泡。...方法二 可以自己写个阻止冒泡事件 然后在发生冒泡的元素中调用这个事件 @click="_stopPropagation($event)" methods:{ _stopPropagation

5.8K10
您找到你想要的搜索结果了吗?
是的
没有找到

Vue 阻止事件冒泡

Vue 阻止事件冒泡 by:授客 QQ:1033553122 开发环境 Win 10 element-ui "2.8.2" Vue 2.9.6 事件冒泡简介 如下图,当我们点击页面某个元素时,会产生点击事件...,事件由外到内,逐层递进(事件捕获阶段,途中的1->2->3->4),当目标元素捕捉到目标事件时,会响应事件,并由内到外,逐层往外传递(事件冒泡阶段,图中的4->5->6->7),这便是事件冒泡。...结论 综合实验1,2,3可知,如果想阻止哪个元素的事件冒泡(即事件只针对该元素有效),只要给该元素的事件增加.stop修饰符即可。...常见的屏蔽右键默认菜单 .passive 每次事件产生,浏览器都会去查询一下是否调用了preventDefault阻止该次事件的默认动作,为事件设置.passive修饰符就是为了告诉浏览器,不用查询了,...我们没用preventDefault阻止默认动作。

3.2K10

JS事件流、事件冒泡阻止冒泡、事件捕获(一看就懂)

讲 事件冒泡阻止冒泡 和 事件捕获 之前先说说什么是事件流,这样会更容易明白 一、事件和事件流 1、什么是事件 事件是可以被 JavaScript 侦测到的行为。...一个完整的JS事件流是从window开始,最后回到window的一个过程。 事件流被分为三个阶段(1~ 5)捕获过程、(5~ 6)事件触发过程、(6~ 10)冒泡过程。...三、阻止冒泡 1、JS阻止事件冒泡 我们用 e.stopPropagation() 这个方法添加到某事件函数里的末尾,就可以做到阻止冒泡事件。...} else { e.cancelBubble = true; //IE阻止冒泡方法 } } 在child(区域①)...2、JQ阻止事件冒泡 jq阻止事件冒泡就简单了,直接在事件函数里面添加 return false; 就行了。

10K53

js 停止事件冒泡 阻止浏览器的默认行为

在前端开发工作中,由于浏览器兼容性等问题,我们会经常用到“停止事件冒泡”和“阻止浏览器默认行为”。...e.stopPropagation ) 3 //因此它支持W3C的stopPropagation()方法 4 e.stopPropagation(); 5 else 6 //否则,我们需要使用IE的方式来取消事件冒泡...(W3C) 10 11 event.preventDefault(); 12 13 } else { 14 15    //IE中阻止函数器默认动作的方式 16...return false; } 但是在使用return false时必须注意: 1、jQuery有自己的事件处理层,也对处理程序做了封装,如果事件处理程序返回false,事件冒泡和浏览器默认事件都会被阻止...2、使用原生javaScript,在事件处理程序中返回false只会阻止浏览器默认行为,而事件冒泡依然存在。 3、浏览器默认行为和事件冒泡是相互独立的。阻止事件冒泡不会影响默认行为,反之亦然。

5.2K120

jquery 事件冒泡阻止事件冒泡 - event.stopPropagation()

事件冒泡机制有时候是不需要的,需要阻止掉,通过 event.stopPropagation() 来阻止 阻止上面点击黄色div的click()冒泡传递 ?...设置了阻止冒泡传递之后,那么click()事件就不会传递到father和grandfather的事件,所以只有一个alert()弹出。 完整事件冒泡示例代码 <script type="text/javascript" src="jquery-3.4.0.min.<em>js</em>...<em>阻止</em>默认行为 <em>阻止</em>表单提交 $('#form1').submit(function(event){ event.preventDefault(); }) 这个是<em>阻止</em>表单提交的默认行为,这个行为和<em>阻止</em><em>冒泡</em>可以合并一起写...使用return false;其实就是使函数传递false的值,从而<em>阻止</em><em>冒泡</em>传递,<em>阻止</em>函数继续执行。

5.5K41

as3.0中如何阻止事件冒泡?

as3.0中的事件冒泡机制有时候会很烦人,比如一个Sprite(方便下文描述就命名为Container吧)把另一外Sprite(称为Child吧)做为子元素套进来以后,如果两个Sprite都注册了Mouse_Down...事件,要想在Child上点击鼠标时系统只响应Child的Mouse_Down事件,默认是不行的,因为事件冒泡会让Container也响应Mouse_Down事件,示例代码: package { import...} } 鼠标点击最小的矩形后,输出如下: _sub_child.MOUSE_DOWN _child.MOUSE_DOWN _container.MOUSE_DOWN 相当于点一个,触发了三个,要想阻止事件冒泡...sub_child.MOUSE_DOWN_2 _sub_child.MOUSE_DOWN_1 小结:如果某对象的一个事件同时添加多个监听,stopPropagation将把该事件注册的所有监听处理函数执行完后,再阻止该事件继续向上冒泡...;而stopImmediatePropagation方法将本次处理函数执行完后就立即阻止事件继续向上冒泡(即同一事件的其它监听函数将不会执行)。

1.5K60

jquery - 页面弹框 - 阻止事件冒泡示例

DOCTYPE html> <script type="text/javascript" src="jquery-3.4.0.min.<em>js</em>...解决#btn的事件<em>冒泡</em>,使用return false; ? 在<em>阻止</em>了#btn按钮的click()事件<em>冒泡</em>到$(document)之后,那么弹框就可以正常显示了。...这个思路不涉及事件<em>冒泡</em>的<em>阻止</em>,但是属于同一个click()方法的<em>阻止</em>,因为点击$(document)的click()事件应该不会<em>冒泡</em>到它下面的元素.pop,不过可以在这里验证一下。...在这个验证的过程中,更加确认了刚才在.pop使用return false;的确是用来<em>阻止</em>click()的<em>冒泡</em>至$(document)的。...DOCTYPE html> <script type="text/javascript" src="jquery-3.4.0.min.<em>js</em>

3.3K10
领券