React合成事件

一、合成事件

    1. event 是 SyntheticEvent ,模拟出来 DOM 事件所有能力
    1. event.nativeEvent 是原生事件对象
    1. 所有的事件,都被挂载到 document 上(React ≤ 16),React17之后是挂载到root组件
    1. 和 DOM 事件不一样,和 Vue 事件也不一样

      div触发事件,DOM事件冒泡到document上,
      document会生成一个统一的合成事件对象
      再派发事件

二、为什么要合成事件机制?

1、更好的兼容性和跨平台

自己实现一套事件机制,尽可能摆脱了DOM事件的逻辑, 更好的兼容性和跨平台

2、挂载到document, 减少内存消耗,避免频繁解绑

事件挂载越多,内存消耗越高,(不用给每个子元素挂载事件,使用冒泡)

看似事件挂载到组件上,其实是在document,组件销毁的时候,也不用解绑事件

3、方便事件的统一管理(如事务机制)

三、React事件绑定

  • React16 绑定到document
  • React 17 18绑定到root组件
  • 有利于多个React版本并存,例如微前端
相关推荐
DanCheOo2 分钟前
从单 Chat 到多 Agent 系统:AI 应用的架构演进路线
前端·agent
开开心心就好9 分钟前
经典塔防游戏移植移动端随时畅玩
java·前端·科技·游戏·edge·django·pdf
We་ct15 分钟前
前端包管理工具与Monorepo全面解析
前端·javascript·npm·pnpm·yarn·monorepo·包管理
Ruihong17 分钟前
Vue 3 defineOptions 宏,用 VuReact 编译成 React 长什么样?
vue.js·react.js·面试
ZPC821020 分钟前
moveit servo 发指令给real arm
java·前端·数据库
sunbin21 分钟前
使用Playwright MCP实现UI自动化测试:从环境搭建到实战案例
前端
倚栏听风雨22 分钟前
Node.js 子进程 fork 完全指南:从入门到踩坑全记录
前端
巴黎没有摩天轮Li22 分钟前
Android 侧 AI 自修复崩溃方案
前端·ai编程
油丶酸萝卜别吃30 分钟前
高效处理数组差异:JS中新增、删除、交集的最优解(Set实现)
开发语言·前端·javascript
GISer_Jing31 分钟前
前端动画技术全解析:从GIF到WebGPU
前端·ai·动画·webgl