addEventListener的第三个参数的作用

从头说起

如果需要给html中的某个dom绑定事件,有三种常用方法:

1.直接写在dom的事件钩子上

<span id="target" onClick="handleClick()">Click me</span>

这种方法破坏了dom和js分离的规则,所以不太被推荐,如果面试官让你做题,尽量别这么写,他们会单纯地以为你很low

2.通过js代码注册事件

var target = document.getElementById('target');
target.onclick = function() {
  // do something...
}

这种方式会比第一种方式更有“仪式感”,但是缺点也显而易见,只能绑定一次事件,下次绑定会清空上次绑定的事件

3.通过addEventListener来注册事件

var target = document.getElementById('target');
target.addEventListener('click', function() {
  // do something...
}, false);    // 如果不加第三个参数,默认是false

这种方式最为灵活,也是被普遍建议采用的事件绑定方式,那么问题来了,这第三个参数是用来干嘛的?

由于浏览器有事件冒泡的机制存在,当你点击一个dom,点击事件会沿着dom树结构像上或者下进行传播,如果你不想被其他相关节点相应到此次点击事件,那么就需要传说中的“阻止事件冒泡”了

假设div、p、span元素都有click事件的响应逻辑,

  • 当第三个参数为false时(不传参数时,默认也是这种冒泡方式),点击<span />后,接下来<p />会响应此次事件,然后是<div />,既事件从上往下冒泡,如下图
propagation-false.png

当第三个参数为true时,点击<span />后,首先响应事件的是最底层的<div />,随后是<p />,最后才是你点击的<span />,如下图

propagation-true.png

__

其他小贴士

  • 如何分辨事件是由冒泡产生的还是操作产生的?
    在事件处理函数中,可以通过
function handleClick (evt) {
  if (evt.phase === 1) {
    // 第三个参数为true时所导致的冒泡
  } else if (evt.phase === 3) {
    // 第三个参数为false时所导致的冒泡
  } else if (evt.phase === 2) {
    // 发生在当前dom的事件
  }
}
  • 如何阻止事件冒泡?
    在事件处理函数中,可以通过
function handleClick(evt) {
  evt.stopPropagation();
  // 或者
  evt.stopImmediatePropagation();
}

上面的阻止冒泡不会阻止本dom本事件的其他事件处理函数的执行;
下面的阻止冒泡会导致后续绑定在该dom的其他事件处理函数不再执行;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • (续jQuery基础(1)) 第5章 DOM节点的复制与替换 (1)DOM拷贝clone() 克隆节点是DOM的常...
    凛0_0阅读 5,274评论 0 8
  • 以下文章为转载,对理解JavaScript中的事件处理机制很有帮助,浅显易懂,特分享于此。 什么是事件? 事件(E...
    jxyjxy阅读 8,215评论 1 10
  • 总结: 鼠标事件 1.click与dbclick事件$ele.click()$ele.click(handler(...
    阿r阿r阅读 5,563评论 2 10
  • 第1章 鼠标事件 1-1 jQuery鼠标事件之click与dbclick事件 用交互操作中,最简单直接的操作就是...
    mo默22阅读 5,062评论 0 6
  • 总以为日子总是连环叠着的,像骨拉多牌一样,翻了一张还有下一张,青春仿佛除用来荒废别无他途,日历本上过一天就圈一点,...
    盼盼童鞋阅读 3,561评论 2 6

友情链接更多精彩内容