事件冒泡和事件捕获是JavaScript中处理事件的两种机制。
事件冒泡:事件从触发元素开始,逐层向上级元素传递的过程。也就是说,如果一个元素的子元素触发了某个事件,那么这个事件不仅会在这个子元素上触发,还会在它的父元素、祖父元素等上层元素上依次触发。
事件捕获:与事件冒泡相反,事件从最外层元素开始,逐层向内层元素传递的过程。也就是说,如果一个元素的子元素触发了某个事件,那么这个事件不仅会在这个子元素上触发,还会在它的祖先元素、祖父元素等下层元素上依次触发。
这两种机制可以通过addEventListener方法的第三个参数来设置。如果设置为true,则表示使用事件捕获;如果设置为false或者不设置,则表示使用事件冒泡。例如:
element.addEventListener('click', function() {
console.log('Clicked!');
}, false); // 使用事件冒泡
element.addEventListener('click', function() {
console.log('Clicked!');
}, true); // 使用事件捕获