js冒泡和捕获

本文深入解析了事件冒泡和捕获机制,解释了它们如何分别向外和向内传递事件。通过示例代码展示了如何使用event.stopPropagation()来阻止这两种事件传播方式,并澄清了事件与监听器的区别。

冒泡是事件向外传递, 捕获是事件向内传递;

event.stopPropagation() 既可以阻止冒泡也可以阻止捕获

阻止冒泡时  事件向 外 传递到添加有stopPropagation()的元素后终止向 外 传

阻止捕获时  事件向 内 传递到添加有stopPropagation()的元素后终止向 内 传

<div onclick="eventProxy()">
    <div>1</div>
    <div>2</div>
    <div>3</div>    
</div>

上面的代码时事件代理, 利用的是事件冒泡的原理。点击每个div 都会触发 eventProxy()。

有些人可能会懵逼,你这不是事件写在父元素的吗子元素获得事件不应该是 从外向内传递吗?这应该是捕获啊?

你要是这么想只能说明  你把事件和监听器当成一回事了,

onclick是个监听器, 监听的事件类型 是 “click”  

你点击div会产生一个 “click”事件 然后事件冒泡到父元素   被onclick监听器监听到触发函数 eventProxy();

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值