`addEventListener` 方法的第三个参数有什么作用?

简介: 【10月更文挑战第29天】`addEventListener` 方法的第三个参数提供了对事件传播阶段的精细控制,使开发人员能够根据具体的业务场景和需求,灵活地处理事件的触发顺序和执行逻辑,从而实现更加丰富和精确的交互效果。

addEventListener 方法的第三个参数是一个可选的布尔值,用于指定事件是在捕获阶段还是冒泡阶段触发,它在事件传播机制中起着重要的作用:

事件传播机制

  • 在JavaScript中,当一个事件发生在一个元素上时,该事件会在DOM树中进行传播,这个传播过程分为三个阶段:捕获阶段、目标阶段和冒泡阶段。
  • 捕获阶段:事件从文档的根节点开始,沿着DOM树向下传播,直到到达触发事件的目标元素。在这个阶段,事件会依次经过从外层到内层的各个祖先元素,如果在某个祖先元素上绑定了捕获阶段的事件监听器,那么该监听器会在事件传播到该元素时被触发。
  • 目标阶段:事件到达触发事件的目标元素,此时会触发该元素上绑定的针对该事件的所有监听器,这些监听器的执行顺序与它们的绑定顺序相同。
  • 冒泡阶段:事件从触发事件的目标元素开始,沿着DOM树向上冒泡,依次触发目标元素的各个祖先元素上绑定的相同类型的事件监听器,直到到达文档的根节点。

第三个参数的作用

  • addEventListener 方法的第三个参数为 true 时,表示在捕获阶段触发事件监听器。这意味着事件会先从外层元素开始向内层元素传播,在传播过程中如果遇到绑定了捕获阶段事件监听器的祖先元素,就会先执行这些监听器,然后才到达目标元素并执行目标元素上的监听器,最后再向上冒泡执行冒泡阶段的监听器。
// 捕获阶段示例
const outer = document.getElementById('outer');
const inner = document.getElementById('inner');

outer.addEventListener('click', function() {
   
  console.log('outer capture');
}, true);

inner.addEventListener('click', function() {
   
  console.log('inner capture');
}, true);

inner.addEventListener('click', function() {
   
  console.log('inner target');
});

outer.addEventListener('click', function() {
   
  console.log('outer bubble');
});

// 当点击 inner 元素时,控制台输出顺序为:outer capture、inner capture、inner target、outer bubble
  • 当第三个参数为 false 或者不传递该参数时,表示在冒泡阶段触发事件监听器。此时事件先到达目标元素并执行目标元素上的监听器,然后再向上冒泡,依次触发祖先元素上的冒泡阶段事件监听器。
// 冒泡阶段示例
const outer = document.getElementById('outer');
const inner = document.getElementById('inner');

outer.addEventListener('click', function() {
   
  console.log('outer bubble');
});

inner.addEventListener('click', function() {
   
  console.log('inner target');
});

outer.addEventListener('click', function() {
   
  console.log('outer capture');
}, true);

inner.addEventListener('click', function() {
   
  console.log('inner capture');
}, true);

// 当点击 inner 元素时,控制台输出顺序为:inner target、outer bubble

实际应用场景

  • 事件委托:在事件委托中,通常利用冒泡阶段的事件传播机制,将事件监听器绑定在父元素上,通过判断事件的目标元素来处理多个子元素的相同类型事件。这样可以减少事件监听器的数量,提高性能。例如,在一个列表中,为列表项添加点击事件,可以将点击事件监听器绑定在列表的父元素上,当列表项被点击时,事件会冒泡到父元素,在父元素的事件处理函数中通过判断事件的目标元素来确定具体是哪个列表项被点击。
const list = document.getElementById('myList');
list.addEventListener('click', function(event) {
   
  if (event.target.tagName === 'LI') {
   
    console.log('点击了列表项:', event.target.textContent);
  }
});
  • 控制事件执行顺序:通过指定第三个参数,可以精确地控制事件监听器的执行顺序,以满足特定的业务需求。例如,在某些情况下,可能需要先执行外层元素的捕获阶段事件监听器,进行一些全局的处理或验证,然后再执行目标元素和冒泡阶段的事件监听器,实现更复杂的交互逻辑。

addEventListener 方法的第三个参数提供了对事件传播阶段的精细控制,使开发人员能够根据具体的业务场景和需求,灵活地处理事件的触发顺序和执行逻辑,从而实现更加丰富和精确的交互效果。

相关文章
|
8月前
|
JavaScript 前端开发
addEventListener()方法中的参数,以及作用
addEventListener()方法中的参数,以及作用
205 1
|
3月前
|
设计模式 Python
深度解密为什么实例在调用方法时会将自身传给 self 参数(二)
深度解密为什么实例在调用方法时会将自身传给 self 参数(二)
50 1
|
3月前
|
缓存 Python
深度解密为什么实例在调用方法时会将自身传给 self 参数(一)
深度解密为什么实例在调用方法时会将自身传给 self 参数
61 0
在调用一个函数时传递了一个参数,但该函数定义中并未接受任何参数
在调用一个函数时传递了一个参数,但该函数定义中并未接受任何参数
136 2
|
8月前
|
存储 C#
C# 方法详解:定义、调用、参数、默认值、返回值、命名参数、方法重载全解析
方法是一段代码,只有在调用时才会运行。 您可以将数据(称为参数)传递给方法。 方法用于执行某些操作,也被称为函数。 为什么使用方法?为了重用代码:定义一次代码,然后多次使用。
159 0
|
8月前
|
前端开发
useEffect 的第二个参数, 传空数组和传依赖数组有什么区别?
在 React 的 useEffect 钩子函数中,第二个参数用于指定依赖项数组。这个参数可以影响 useEffect 的触发时机和频率。在 React 的 useEffect 钩子函数中,第二个参数用于指定依赖项数组。这个参数可以影响 useEffect 的触发时机和频率。
223 0
|
8月前
|
小程序
小程序封装组件简单案例,所有小程序适用(传入参数、外抛事件、传入样式)
小程序封装组件简单案例,所有小程序适用(传入参数、外抛事件、传入样式)
103 0
|
C# 数据安全/隐私保护
C# 窗体之间参数互相传递的两种方法与使用
C# 窗体之间参数互相传递的两种方法与使用
|
JavaScript 开发者
指令-使用钩子函数的第二个binding参数拿到传递的值|学习笔记
快速学习指令-使用钩子函数的第二个binding参数拿到传递的值
指令-使用钩子函数的第二个binding参数拿到传递的值|学习笔记
|
编译器
详解函数的三种传递方式
详解函数的三种传递方式
223 0