e.target 和 e.currentTarget 的区别

在前端开发中,e.targete.currentTarget 是事件对象(Event)中两个常用的属性,它们的主要区别在于指向的元素不同,具体如下:

1. e.target

  • 定义 :指向触发事件的具体元素(事件的实际发源地)。
  • 特点 :如果事件经过了冒泡,e.target 始终是最内层的、实际被点击(或触发)的元素。

2. e.currentTarget

  • 定义 :指向当前正在处理事件的元素(即绑定了事件监听器的元素)。
  • 特点 :与 this(在普通函数中)指向相同,始终是绑定事件的那个元素,不受事件冒泡影响。

示例说明

假设 HTML 结构如下:

html 复制代码
<div id="outer" style="padding: 50px; background: pink;">
  外层元素
  <div id="inner" style="padding: 30px; background: lightblue;">
    内层元素
  </div>
</div>

JS 代码:

javascript 复制代码
const outer = document.getElementById('outer');
outer.addEventListener('click', function(e) {
  console.log('e.target:', e.target.id);      // 实际点击的元素
  console.log('e.currentTarget:', e.currentTarget.id);  // 绑定事件的元素(outer)
  console.log('this:', this.id);              // 与 currentTarget 相同(outer)
});
  • 点击内层元素(inner)

    • e.targetinner(实际触发事件的元素)
    • e.currentTargetouter(绑定事件的元素)
    • thisouter
  • 点击外层元素(outer,非 inner 区域)

    • e.targetouter
    • e.currentTargetouter
    • thisouter

总结

  • e.target:谁触发了事件,就指向谁(事件源头)。

  • e.currentTarget:谁绑定了事件,就指向谁(事件处理器所在的元素)。

在事件委托(利用冒泡机制)时,这两个属性的区别尤为重要。例如,通过外层元素代理内层元素的事件时,e.target 可获取具体操作的内层元素,而 e.currentTarget 始终是外层代理元素。

相关推荐
@小红花35 分钟前
从0到1学习Vue框架Day03
前端·javascript·vue.js·学习·ecmascript
前端与小赵37 分钟前
vue3中 ref() 和 reactive() 的区别
前端·javascript·vue.js
魔云连洲1 小时前
Vue的响应式底层原理:Proxy vs defineProperty
前端·javascript·vue.js
专注VB编程开发20年1 小时前
CSS定义网格的列模板grid-template-columns什么意思,为什么要用这么复杂的单词
前端·css
IT_陈寒1 小时前
Redis性能提升50%的7个关键优化策略,90%开发者都不知道第5点!
前端·人工智能·后端
Hilaku1 小时前
深入URL和URLSearchParams:别再用正则表达式去折磨URL了
前端·javascript·代码规范
pubuzhixing1 小时前
Canvas 的性能卓越,用它解决一个棘手问题
前端
weixin_456904271 小时前
Vue.jsmain.js/request.js/user.js/store/index.js Vuex状态管理项目核心模块深度解析
前端·javascript·vue.js
伍哥的传说1 小时前
Vue 3.6 Alien Signals:让响应式性能飞跃式提升
前端·javascript·vue.js·vue性能优化·alien-signals·细粒度更新·vue 3.6新特性
永日456701 小时前
学习日记-HTML-day51-9.9
前端·学习·html