事件冒泡机制

一、单机事件冒泡机制

  • 子父元素具有click,执行的时候会冒泡执行(由里向外执行该事件)
<div id="box" style="width: 100px;height: 100px;background-color: orangered">
   <button id="btn">按钮</button>
</div>
<script>
	var num = 0;
   btn.onclick = function(){
       num++;
       console.log(this,num);
   }
   box.onclick = function(){
       num++;
       console.log(this,num);
   }
</script>

在这里插入图片描述

二、如何处理事件冒泡

  • return false----原生js里面不能阻止事件冒泡
  • 通过事件执行参数event来解决

1. e.stopPropagation()处理事件冒泡

  • 下面的event是事件对象,也可以直接写在事件的执行函数上(以形参的形式)
var num = 0;
btn.onclick = function(){
  num++;
  console.log(this,num);
  var e = window.event||event;
  e.stopPropagation();
}

在这里插入图片描述

var num = 0;
btn.onclick = function(e){
  num++;
  console.log(this,num);
  console.log(e);
}

在这里插入图片描述

输出MouseEvent事件执行参数对象

var num = 0;
btn.onclick = function(e){
  num++;
  console.log(this,num);
  e.stopPropagation();
}
box.onclick = function(){
  num++;
  console.log(this,num);
}

在这里插入图片描述

2. e.cancelBubble = true处理事件冒泡

var num = 0;
btn.onclick = function(e){
  num++;
  console.log(this,num);
  e.cancelBubble = true;
}
box.onclick = function(){
  num++;
  console.log(this,num);
}

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南初️

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值