js阻止子元素事件_JS阻止冒泡和取消默认事件(默认行为)-前端开发博客

本文详细介绍了JavaScript中如何阻止事件冒泡,使用`event.stopPropagation()`和`event.cancelBubble = true`,以及如何取消默认事件,通过`event.preventDefault()`和`event.returnValue = false`。文中通过实例展示了如何在不同浏览器中实现这些功能,并提供了相关代码示例。同时,还提到了事件对象`event`的注意事项和跨浏览器问题,特别是`window.event`在IE与Firefox中的差异。
摘要由CSDN通过智能技术生成

js冒泡和捕获是事件的两种行为,使用event.stopPropagation()起到阻止捕获和冒泡阶段中当前事件的进一步传播。使用event.preventDefault()可以取消默认事件。对于冒泡和捕获的优先顺序请看之前文章:JavaScript捕获和冒泡探讨

防止冒泡和捕获

w3c的方法是e.stopPropagation(),IE则是使用e.cancelBubble = true

stopPropagation也是事件对象(Event)的一个方法,作用是阻止目标元素的冒泡事件,但是会不阻止默认行为。什么是冒泡事件?如在一个按钮是绑定一个”click”事件,那么”click”事件会依次在它的父级元素中被触发 。stopPropagation就是阻止目标元素的事件冒泡到父级元素。如:

  • test

上面的代码,Demo如下,我们单击test时,会依次触发alert(“li”),alert(“ul”),alert(“div”),这就是事件冒泡。

冒泡事件

阻止冒泡window.event? window.event.cancelBubble = true : e.stopPropagation();

停止冒泡

取消默认事件

w3c的方法是e.preventDefault(),IE则是使用e.returnValue = false;

preventDefault它是事件对象(Event)的一个方法,作用是取消一个目标元素的默认行为。既然是说默认行为,当然是元素必须有默认行为才能被取消,如果元素本身就没有默认行为,调用当然就无效了。什么元素有默认行为呢?如链接,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值