浏览器中的事件冒泡,事件捕获,事件委托

事件冒泡

事件冒泡(dubbed bubbling):当一个元素接收到事件的时候,会把他接收到的事件传给自己的父级,一直到 window。

会冒泡的事件有:

  • 鼠标事件:click, dblclick, mousemove,
  • 键盘事件:keyup, keydown
  • 表单事件:input, change, submit
  • 触摸事件:drag, dragstart, dragend

不会冒泡的事件有:

  • 焦点事件:focus, blur

  • 鼠标事件:mouseenter, mouseleave

  • 媒体事件:play, pause, ended

    事件源 =>根节点(由内到外)进行事件传播。

给三个盒子依次绑定点击事件,当点击最小small盒子的时候,会依次触发父级元素的点击事件。

有些时候我们不希望产生事件冒泡,所以可以 在子事件中加入e.stopPropagation() 取消冒泡

事件捕获

事件捕获(event capturing): 当鼠标点击或者触发dom事件时(被触发dom事件的这个元素被叫作事件源),浏览器会从根节点 =>事件源(由外到内)进行事件传播。

事件捕获与事件冒泡是比较类似的,最大的不同在于事件传播的方向。

click small box

一个事件的完整生命周期分为三个阶段:

  1. 捕获阶段 (Capturing Phase): 事件从windowdocument开始,向下传播到目标元素。
  2. 目标阶段 (Target Phase): 事件到达并被目标元素本身处理。
  3. 冒泡阶段 (Bubbling Phase): 事件从目标元素向上回溯到windowdocument注意: 并不是所有事件都会冒泡(例如 focusblurmouseentermouseleave 等事件默认不冒泡)。

事件委托

事件委托也称为事件代理。就是利用事件冒泡,把子元素的事件都绑定到父元素上。如果子元素阻止了事件冒泡,那么委托就无法实现。

应用场景:1000个button需要注册点击事件

如果循环给每个按钮添加点击事件,那么会增加内存损耗,影响性能

此时可以给button的父元素添加点击事件

这时相当于每个按钮都绑定了点击事件

优点:

替代循环绑定事件的操作,减少内存消耗,提高性能。比如: 在table上代理所有td的click事件。 在ul上代理所有li的click事件。

简化了dom节点更新时,相应事件的更新。比如: 不用在新添加的li上绑定click事件。 当删除某个li时,不用移解绑上面的click事件。

缺点:

  1. 事件委托基于冒泡,对于不冒泡的事件不支持。
  2. 层级过多,冒泡过程中,可能会被某层阻止掉。
  3. 理论上委托会导致浏览器频繁调用处理函数,虽然很可能不需要处理。所以建议就近委托,比如在table上代理td,而不是在document上代理td。

事件对象

只有在事件处理程序期间,event对象才会存在,一旦事件处理程序执行完成,event对象就会被销毁

event对象里需要关心的两个属性:

  1. target:target永远是被添加了事件的那个元素;

  2. eventPhase:调用事件处理程序的阶段,有三个值

    1. 捕获阶段;
    2. 处于目标;
    3. 冒泡阶段;

preventDefault与stopPropagation

preventDefault:比如链接被点击默认会导航到其href指定的URL, <input type="checkbox"> 默认会切换选中状态。

js 复制代码
const myForm = document.getElementById('myForm');

  myForm.addEventListener('submit', function(event) {
    // 阻止表单的默认提交行为
    event.preventDefault();

    const inputValue = document.getElementById('myInput').value;
    // 你可以在这里使用 AJAX 将 inputValue 发送到服务器,
    // 或者进行客户端验证等
    console.log('表单提交被阻止,输入的值是:', inputValue);
    alert('表单提交被阻止,请检查控制台。');
  });

stopPropagation:立即停止事件在DOM层次中的传播,包括捕获和冒泡事件;但是同一节点上的其他listener还会被执行,如果要同一级的listener也不执行,使用stopImmediatePropagation()

引用

【面试题】对JS中的事件冒泡、事件捕获、事件委托的理解_面试问到事件冒泡和事件捕获怎么说-CSDN博客

相关推荐
passerby606141 分钟前
完成前端时间处理的另一块版图
前端·github·web components
掘了1 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅1 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅1 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅2 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment2 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅2 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊2 小时前
jwt介绍
前端
爱敲代码的小鱼2 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax
Cobyte3 小时前
AI全栈实战:使用 Python+LangChain+Vue3 构建一个 LLM 聊天应用
前端·后端·aigc