事件委托通过父元素监听冒泡事件来统一处理子元素交互,减少监听器数量、适配动态内容、节省内存;需注意事件冒泡限制、父容器稳定性及精准目标过滤。
事件委托利用事件冒泡机制,把子元素的事件监听逻辑统一交给父元素处理,避免为大量子元素重复绑定事件,从而减少内存占用、提升页面性能。
DOM事件会从目标元素向上逐层冒泡到根节点。只要父元素监听了某个事件(如 click),当子元素触发该事件时,父元素也能捕获并响应——前提是子元素没有调用 event.stopPropagation() 阻断冒泡。
关键在于通过 event.target 判断真正被点击的是哪个子元素,再执行对应逻辑。
以动态增删列表项为例:
都调用 li.addEvent
Listener('click', handler)
绑定一次 click 监听器代码示例:
document.querySelector('ul').addEventListener('click', function(e) {
if (e.target.tagName === 'LI') {
console.log('点击了列表项:', e.target.textContent);
}
});
主要体现在三方面:
事件委托不是万能的,需注意: