美文网首页
addEventListener的第三个参数的作用

addEventListener的第三个参数的作用

作者: 天秤座的牛宝宝 | 来源:发表于2017-09-11 17:07 被阅读0次

从头说起

如果需要给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的其他事件处理函数不再执行;

相关文章

  • addEventListener的第三个参数的作用

    从头说起 如果需要给html中的某个dom绑定事件,有三种常用方法: 1.直接写在dom的事件钩子上 这种方法破坏...

  • js事件

    事件冒泡 addEventListener 第三个参数为false 默认模式 事件捕获 addEventL...

  • addEventListener的第三个参数到底该怎么设置

    第三个参数可以设置啥? 从官方文档看,addEventListener 方法使用如下: target.addEve...

  • [HTML] target phase事件顺序

    我们知道addEventListener的第三个参数,useCapture用来标识该事件监听函数用于处理什么阶段的...

  • 事件的捕获和冒泡

    这里涉及到addEventListener的三个参数:第一个参数:事件类型第二个参数:事件的处理函数第三个参数:指...

  • 事件冒泡和捕获通俗理解

    addEventListener 第三个参数:true: 捕获阶段触发事件false: 冒泡阶段触发事件默认值是 ...

  • 2019-11-04 JS 事件冒泡和捕获

    联系: 都是事件触发时序的问题绑定事件方法(addEventListener)的第三个参数是控制事件触发顺序的;默...

  • HTML DOM addEventListener()第三个参数

    ...可能有人会说这是水贴, 可是我真的一直对addEventListener第三个参数不太懂, 因此令开一贴, ...

  • 事件

    当dom元素被删除时,其绑定的事件也会消失 addEventListener 目前第三个参数可以为布尔值或对象 为...

  • 简述passive属性

    导语 在不知道哪个版本的浏览器DOM更新了addEventListener这个方法 本来这个方法的第三个参数 是u...

网友评论

      本文标题:addEventListener的第三个参数的作用

      本文链接:https://www.haomeiwen.com/subject/meefsxtx.html