React的合成事件(SyntheticEventt)

文章目录

  • 前言


前言

React的合成事件(SyntheticEvent)是React为了统一不同浏览器的事件处理行为而封装的一套跨浏览器事件系统。它与原生事件的主要区别如下:


1. 事件绑定方式
• 合成事件:使用驼峰命名法绑定事件(如onClick),并通过JSX直接传递给组件。

  <button onClick={handleClick}>点击</button>

• 原生事件:通过addEventListener或HTML属性(小写命名,如onclick)绑定。

  button.addEventListener('click', handleClick);

2. 事件委托机制
• 合成事件:React将事件委托到根节点(如React 17 之前是 document,React 17+的root节点),通过事件冒泡捕获子组件的事件,而非直接绑定到目标元素。这减少了内存消耗,并简化了动态元素的处理。

• 原生事件:直接绑定到具体元素,可能因频繁的元素增删导致内存问题。


3. 事件对象
• 合成事件:接收的是SyntheticEvent对象,封装了原生事件对象,统一了跨浏览器的属性(如e.targete.stopPropagation())。

• 原生事件:直接使用浏览器提供的Event对象,不同浏览器的行为和属性可能存在差异。


4. 事件池(Event Pooling)
• 合成事件:事件对象会被重用(出于性能考虑),异步代码中访问事件属性需调用e.persist()

handleClick = (e) => {e.persist(); // 保留事件对象setTimeout(() => console.log(e.target), 100);
};

• 原生事件:事件对象不会被重用,可直接在异步代码中使用。


5. 事件传播与阻止冒泡
• 合成事件:e.stopPropagation()仅阻止合成事件的传播,不影响原生事件。

• 原生事件:e.stopPropagation()会阻止事件的捕获/冒泡,可能导致React合成事件无法触发(如果事件未冒泡到根节点)。


6. 执行顺序
• 同级事件:直接绑定在元素上的原生事件先于合成事件执行。

• 父子元素:

  1. 原生捕获阶段事件(如addEventListener('click', handler, true))。
  2. 合成捕获阶段事件(如onClickCapture)。
  3. 原生冒泡阶段事件。
  4. 合成冒泡阶段事件。

7. 自动绑定管理
• 合成事件:React在组件挂载/卸载时自动处理事件绑定与解绑。

• 原生事件:需手动通过removeEventListener解绑,否则可能导致内存泄漏。


8. 兼容性
• 合成事件:统一处理浏览器兼容性问题(如IE的event.targetevent.srcElement差异)。

• 原生事件:需开发者自行处理兼容性。


9. 事件类型覆盖
• 合成事件:支持常见事件(如onChangeonMouseEnter),但特殊事件(如resize)需通过原生事件处理。

• 原生事件:支持所有浏览器事件。


示例:混合使用时的行为

function App() {const handleSyntheticClick = () => console.log("合成事件");const handleNativeClick = () => console.log("原生事件");useEffect(() => {document.addEventListener("click", handleNativeClick);return () => document.removeEventListener("click", handleNativeClick);}, []);return <button onClick={handleSyntheticClick}>按钮</button>;
}

点击按钮时,输出顺序为:

  1. 原生事件(直接绑定在document上的冒泡阶段事件)。
  2. 合成事件(通过React根节点委托处理)。

总结
React合成事件通过封装原生事件,提供了跨浏览器一致性、性能优化和便捷的事件管理,但在混合使用时需注意执行顺序和事件传播的影响。对于特殊场景(如非冒泡事件scroll),仍需依赖原生事件处理。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/81674.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

报表控件stimulsoft教程:如何在报表和仪表板中创建热图

Stimulsoft Ultimate &#xff08;原Stimulsoft Reports.Ultimate&#xff09;是用于创建报表和仪表板的通用工具集。该产品包括用于WinForms、ASP.NET、.NET Core、JavaScript、WPF、PHP、Java和其他环境的完整工具集。无需比较产品功能&#xff0c;Stimulsoft Ultimate包含了…

[免费]苍穹微信小程序外卖点餐系统修改版(跑腿点餐系统)(SpringBoot后端+Vue管理端)【论文+源码+SQL脚本】

大家好&#xff0c;我是java1234_小锋老师&#xff0c;看到一个不错的微信小程序医院预约挂号管理系统(uni-appSpringBoot后端Vue管理端)&#xff0c;分享下哈。 项目视频演示 【免费】苍穹微信小程序外卖点餐系统修改版(跑腿点餐系统)(SpringBoot后端Vue管理端) Java毕业设计…

Dify 快速上手 MCP!Java 搭建 MCP Server 接入 Dify详细实战攻略

近期&#xff0c;MCP协议在AI领域热度飙升&#xff0c;成为众多开发者和行业人士热议的焦点。下文先介绍MCP究竟是什么&#xff1f;再详细讲下 Dify DeepSeek Java开发 MCP server 实战。 一、MCP的基本概念 MCP&#xff0c;全称为模型上下文协议&#xff08;Model Context P…

力扣992做题笔记

左神做法的理论依据 我们可以通过 集合的包含关系 和 具体示例枚举 来直观理解这一推导过程。以下结合题目示例 1 进行详细说明&#xff1a; 示例 1 分析 输入&#xff1a;nums [1,2,1,2,3], k 2 目标&#xff1a;计算恰好包含 2 种不同整数 的子数组个数。 步骤一集合 A…

Kubernetes 运维操作手册:从 etcd 快照进行精确恢复

1 5 步实现 etcd 精确恢复 将快照恢复到本地 etcd 数据目录。使用恢复的数据启动本地 etcd 实例。使用 etcdctl 查询特定键&#xff08;例如&#xff0c;ConfigMap&#xff09;。使用 auger 解码以提取干净的 YAML。使用 kubectl 申请恢复到您的实时集群。 本指南将指导您从 et…

LeetCode Hot100刷题——合并区间

56. 合并区间 以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间&#xff0c;并返回 一个不重叠的区间数组&#xff0c;该数组需恰好覆盖输入中的所有区间 。 示例 1&#xff1a; 输入&#xff1a;i…

《Metasploit框架核心模块解析与安全防护实践》​

目录 ​​一、框架模块化设计与安全验证价值​​ ​​1. 漏洞验证模块&#xff08;Exploit Modules&#xff09;​​ ​​2. 安全评估模块&#xff08;Auxiliary Modules&#xff09;​​ ​​3. 安全响应模块&#xff08;Post-Exploitation&#xff09;​​ ​​4. 载荷安全…

Cribl 中 Parser 扮演着重要的角色 + 例子

先看文档: Parser | Cribl Docs Parser The Parser Function can be used to extract fields out of events or reserialize (rewrite) events with a subset of fields. Reserialization will preserve the format of the events. For example, if an event contains comma…

程序设计实践--排序(1)

&#xff11;、插入排序&#xff08;一个数组&#xff09; #include<bits/stdc.h> using namespace std; const int N1e35; int a[N]; int n; int main(){cin>>n;for(int i1;i<n;i){cin>>a[i];}for(int i1;i<n;i){int va[i];int ji-1;while(j>1&am…

MAC电脑中右键后复制和拷贝的区别

在Mac电脑中&#xff0c;右键菜单中的“复制”和“拷贝”操作在功能上有所不同&#xff1a; 复制 功能&#xff1a;在选定的位置创建一个与原始文件相同的副本。快捷键&#xff1a;CommandD用于在当前位置快速复制文件&#xff0c;CommandC用于将内容复制到剪贴板。效果&…

新能源汽车焊接智能节气阀

在新能源汽车产业迅猛发展的浪潮中&#xff0c;制造工艺的优劣直接关系到车辆的性能、安全与市场竞争力。焊接&#xff0c;作为新能源汽车生产流程里的关键一环&#xff0c;无论是构建车身框架&#xff0c;还是连接电池模组&#xff0c;其质量的好坏都起着决定性作用。而在焊接…

Linux:面试题

1. 什么是中断和异常&#xff1f; 中断&#xff1a;由外部设备&#xff08;如键盘、网卡&#xff09;触发的异步事件&#xff0c;用于通知 CPU 有紧急事件需要处理。 异常&#xff1a;由 CPU 内部执行指令时产生的同步事件&#xff08;如除零错误、缺页异常&#xff09;&#…

linux关闭某端口暂用的进程

查看是哪个端口暂用 sudo netstat -tulpn | grep :80根据图片 显示 80端口暂用的 进程id是 3002 结束进程id为3002的进程 sudo kill -9 3002

【学习心得】Jupyter 如何在conda的base环境中其他虚拟环境内核

如果你在conda的base环境运行了jupyter lab打开了一个ipynb文本&#xff0c;此时选择的内核是base虚拟环境的Python内核&#xff0c;如果我想切换成其他conda虚拟环境来运行这个文件该怎么办&#xff1f;下面我们试着还原一下问题&#xff0c;并且解决问题。 【注】 这个问题出…

React Flow 边的基础知识与示例:从基本属性到代码实例详解

本文为《React Agent&#xff1a;从零开始构建 AI 智能体》专栏系列文章。 专栏地址&#xff1a;https://blog.csdn.net/suiyingy/category_12933485.html。项目地址&#xff1a;https://gitee.com/fgai/react-agent&#xff08;含完整代码示​例与实战源&#xff09;。完整介绍…

ZooKeeper 原理解析及优劣比较

大家好&#xff0c;这里是架构资源栈&#xff01;点击上方关注&#xff0c;添加“星标”&#xff0c;一起学习大厂前沿架构&#xff01; 引言 在分布式系统中&#xff0c;服务注册、配置管理、分布式锁、选举等场景都需要一个高可用、一致性强的协调服务。Apache ZooKeeper 凭…

模糊照片变清晰:照片高清修复 ComfyUI 使用教学

模糊照片变清晰 满心欢喜地翻出旧相册&#xff0c;想重温那些美好的回忆&#xff0c;结果照片却模糊不清&#xff0c;根本看不清当年的模样&#xff1b;又或者精心拍摄了一张超有氛围感的照片&#xff0c;结果因为手抖或者光线问题&#xff0c;变得模糊&#xff0c;无法发朋友圈…

IEEEtran中文献中的作者大于3个时,用et al.省略

latex&#xff1a; 在使用bib文件的时候&#xff0c;当参考文献超过三个作者时&#xff0c;第三个作者后加逗号并接上et al.。我使用的是IEEEtran.bst。 \begingroup \small \bibliographystyle{IEEEtran} \bibliography{newbmyref1} \endgroup1.需要将IEEEtran.bst添加到这个…

Android Studio Kotlin 中的方法添加灰色参数提示

在使用 Android Studio 时&#xff0c; 我发现使用 Java 编写方法后在调用方法时&#xff0c; 会自动显示灰色的参数。 但在 Kotlin 中没有显示&#xff0c; 于是找了各种方法最后找到了设置&#xff0c; 并且以本文章记录下来。 博主博客 https://blog.uso6.comhttps://blog.…

python宠物用品商城系统

目录 技术栈介绍具体实现截图系统设计研究方法&#xff1a;设计步骤设计流程核心代码部分展示研究方法详细视频演示试验方案论文大纲源码获取/详细视频演示 技术栈介绍 Django-SpringBoot-php-Node.js-flask 本课题的研究方法和研究步骤基本合理&#xff0c;难度适中&#xf…