如何实现Html事件冒泡

如何实现Html事件冒泡,第1张

今天在修改后台的一个模块,中发现一个button在点击时,触发了表单提交,我在onclick中加入了return,这个在提交之前就应该返回了,不该出现这个问题。转念一想,我觉得我应该时事件冒泡了,也就是一个子元素的事件触发了父元素的事件的触发。

简单说一下,解决方案吧,对于button,如果在表单中,相当于submit一样的存在,加入type="button"这个,就可以不发生事件的冒泡了。在工作中我们还可以遇到html的a标记的事件冒泡的问题,如何防止a标记事件冒泡?首先对a标记加上 href="javascript:void(0)"这样就可以防止冒泡,然后把一些这个上面的 *** 作,放到onclick方法中去 *** 作,这样就可以解决a标记事件冒泡的问题了。

当事件( event )触发在某个元素上时,如果这个事件绑定了方法那么这个方法会被执行,如果没有绑定方法或者被绑定的方法返回 true ,那么这个事件会向其父级传播,一层一层直到最顶层即 document 或者 window ,除非被认为的中断。

现代浏览器的冒泡机制基本一致,事件都是由最内层的元素网最外层元素冒泡,冒泡顺序:child->paren->body->html->document->window。可能早期浏览器(IE5、IE6等)有所区别。

事件的捕获刚好和冒泡的方向相反,由最外层开始捕获,然后到最内层,捕获顺序:window->document->html->body->paren->child。

事件捕获优先发生而冒泡后发生,这样一来从捕获到冒泡形成了一组事件流。

通过 addEventListener(event,fn,useCapture) 这个方法给 DOM 绑定事件时,前两个参数很容易理解一个是事件名称 event ,第二个是触发方法 fn ,其中第三个参数是一个 bool 值,用来设置绑定的方法是在事件捕获(true)时执行还是冒泡(false)时执行,一般我们会设置 false,这样比较安全。

通常情况下,我们不会去做阻止事件冒泡的事情,但是有时候当我们不想同时执行绑定在两个 DOM 元素上的事件时,我们需要手动的阻止事件的冒泡,通常我们使用如下几种方式来阻止:

默认事件:该元素默认执行的动作。例如:button 的默认事件是 submit,a 的默认事件是打开链接 等等


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7013774.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-31
下一篇 2023-03-31

发表评论

登录后才能评论

评论列表(0条)

保存