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

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,这就是事件冒泡。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值