时间:2021-05-25
今天整理笔记,发现在学习javaScript的过程中,遇到过一个在当时看来很棘手的问题,现在特地总结一下,也希望能帮助到曾像我一样迷惘的初学者。
我还是以一个案例来说明问题,html代码如下:
<div onclick="show('a')"> <p onclick="show('b')"></p> </div>css代码如下:
div{ width:500px; height:500px; background:red; } p{ width:200px; height:200px; background:blue; }js代码如下:
function show(info){ alert(info); }稍微懂点js的人都知道当我点击p时,基于事件冒泡机制,会触发父元素div的onclick事件,结果是先弹出b、再弹出a。
那么问题来了,如何修改show()这个函数而只弹出b?我第一次的解决方法是(各位大神勿喷):
function show(e,info){ function cancelBubble(e){ e = e || window.event; if (e.stopPropagation) { e.stopPropagation(); }else { e.cancelBubble = true; } } alert(info);}结果老是报错。我就开始各种百度,最终解决方法如下:
function show(info){ alert(info); cancelBubble();}function cancelBubble(e) { var evt = e ? e : window.event; if (evt.stopPropagation) { //W3C evt.stopPropagation(); }else { //IE evt.cancelBubble = true; } }至于为什么这样?我分析的是这样做有两个好处:1.阻止了事件冒泡,达到只弹出b目的; 2.将阻止事件冒泡的代码封装成了一个函数,可以多次调用。
好了,问题圆满解决。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
阻止事件冒泡行为,要是不阻止的话,点击div的时候也会同时触发body事件html代码clickthiscss代码div{width:200px;height:
实现也很简单,但需要注意的是,在点击显示的事件中,需要做阻止事件冒泡的处理,否则就触发页面的点击事件了。但这样做也有一个缺点,即如果同一个页面中如果也有事件阻止
JavaScript中捕获/阻止捕获、冒泡/阻止冒泡 事件流描述的是从页面中接收事件的顺序。提出事件流概念的正是IE和Netscape,但是前者提出的是我们常
思路一第一种思路分两步第一步:对document的click事件绑定事件处理程序,使其隐藏该div第二步:对div的click事件绑定事件处理程序,阻止事件冒泡
使用vue阻止子级元素的click事件冒泡,很简单,用stop按钮1按钮2这样点击div里面的按钮1,就不会触发div绑定时间test1()方法。以上这篇vue