Javascript(三十九)事件冒泡

事件流:事件流是描述从页面接收事件的顺序,当几个都具有事件的元素层叠在一起的时候,那么你点击其中一个元素,并不是只有当前点击的元素会触发事件,而层叠在你点击范围的所有元素都会触发事件。事件流包括两种模式:冒泡和捕获
事件冒泡:现代浏览器默认情况下都是冒泡模式
在这里插入图片描述
上图:我只点击box3 应该只是触发box3的事件处理函数,可是box2,box也跟着触发了。这就是由子元素冒泡形成从里到外的层级影响,也就是事件冒泡。下图可以看到,只有点击box的时候,才不会出现冒泡。因为box没有祖先元素了。

注:这是浏览器天生的一个特点,称为事件冒泡
点击box2
在这里插入图片描述
点击box
在这里插入图片描述
阻止事件冒泡:

cancleBubble=true
在这里插入图片描述
stopProgapation()
在这里插入图片描述

阻止事件冒泡:浏览器兼容处理

function stopBubble(e){
			
				if(e.stopPropagation){
					e.stopPropagation()
				}else{
					e.cancelBubble=true;
				}
			}

在这里插入图片描述

事件捕获:点击box3,引起事件冒泡,box2,box跟着发生点击事件

事件发生顺序:box->box2->box3 (从里到外)
在这里插入图片描述
当事件捕获和冒泡事件同时出现时,先捕获后冒泡⭐最里的元素节点是先冒泡后捕获。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值