一文快速学会阻止事件冒泡的4种方法(原生js阻止,vue中使用修饰符阻止)
阻止事件冒泡的方法
前端结构
<div id="app">
<div class="father-box" @click="clickFatherBox">
我是父盒子
<div class="son-box" @click="clickSonBox">
我是子盒子
</div>
</div>
</div>
methods: {
clickSonBox(){
alert("子盒子")
},
clickFatherBox(){
alert("父盒子")
}
},
事件冒泡:clickSonBox事件发生时clickFatherBox事件也被触发了
此时点击子盒子 对话框弹出两次
方法1:使用js阻止事件冒泡
clickSonBox(e){
e.stopPropagation();
alert("子盒子")
},
//或者
clickSonBox(e){
e.cancelBubble=true
alert("子盒子")
},方法2:使用事件修饰符stop
绑定事件时,使用stop修饰符阻止事件冒泡
<div class="father-box" @click="clickFatherBox">我是父盒子
<div class="son-box" @click.stop="clickSonBox">
我是子盒子
</div>
</div>
方法3:使用事件修饰符self
绑定事件时,使用self修饰符 表示只在本元素被点击时触发
<div class="father-box" @click.self="clickFatherBox">
我是父盒子
<div class="son-box" @click="clickSonBox">
我是子盒子
</div>
</div>
注意:
self修饰符应该在父盒子绑定事件时使用而不是子盒子! 在父盒子事件使用self,点击了子盒子,父盒子的点击事件不会被触发,即事件没有冒泡,
self表示只在当前元素发生事件时,事件才触发
总结
到此这篇关于阻止事件冒泡的4种方法(原生js阻止,vue中使用修饰符阻止)的文章就介绍到这了,更多相关前端阻止事件冒泡方法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue 解决通过this.$refs来获取DOM或者组件报错问题
这篇文章主要介绍了Vue 解决通过this.$refs来获取DOM或者组件报错问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-07-07
vue+echarts实现可拖动节点的折线图(支持拖动方向和上下限的设置)
制作一个折线图用于显示当前24小时的数据,并且可以通过拖动折现图设置数据,接下来通过本文给大家分享vue+echarts实现可拖动节点的折线图(支持拖动方向和上下限的设置),感兴趣的朋友跟随一起学习吧2019-04-04
Vue使用axios(Ajax)+ElementUI实现登录实践
本文介绍了如何使用Vue和ElementUI框架创建一个登录页面,并实现前后端交互,同时,还讨论了跨域问题的解决方案以及ES6中的箭头函数2026-03-03


最新评论