什么是html的事件冒泡,什么是事件冒泡?

本文解析了当DOM元素接收到点击事件时,如何通过冒泡过程让事件从子元素传递到父元素直至window。通过HTML结构实例和JavaScript代码展示,详细讲解了addEventListener的useCapture选项及其在事件传播中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==

当事件发生在DOM元素上时,该事件并不完全发生在那个元素上。在冒泡阶段,事件冒泡,或者事件发生在它的父代,祖父母,祖父母的父代,直到到达window为止。

假设有如下的 HTML 结构:

1

对应的 JS 代码:

function addEvent(el, event, callback, isCapture = false) {

if (!el || !event || !callback || typeof callback !== 'function') return;

if (typeof el === 'string') {

el = document.querySelector(el);

};

el.addEventListener(event, callback, isCapture);

}

addEvent(document, 'DOMContentLoaded', () => {

const child = document.querySelector('.child');

const parent = document.querySelector('.parent');

const grandparent = document.querySelector('.grandparent');

addEvent(child, 'click', function (e) {

console.log('child');

});

addEvent(parent, 'click', function (e) {

console.log('parent');

});

addEvent(grandparent, 'click', function (e) {

console.log('grandparent');

});

addEvent(document, 'click', function (e) {

console.log('document');

});

addEvent('html', 'click', function (e) {

console.log('html');

})

addEvent(window, 'click', function (e) {

console.log('window');

})

});

addEventListener方法具有第三个可选参数useCapture,其默认值为false,事件将在冒泡阶段中发生,如果为true,则事件将在捕获阶段中发生。如果单击child元素,它将分别在控制台上记录child,parent,grandparent,html,document和window,这就是事件冒泡。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值