React 19 带来了 JSX 运行时的重要更新

devtools/2024/10/20 8:46:00/

在 React 的发展历程中,JSX 运行时一直扮演着重要的角色。在以前的的版本,JSX 运行时会克隆传入的 props 对象,这背后有着两大原因。

历史原因

React 保留了一些特殊的 prop 名称,如 key 和在 React 19 之前的 ref。这些 prop 并非普通属性,而是 React 内部机制的一部分,它们不会在目标组件中直接可见。

React 在将 props 对象传递给用户组件之前,会利用这些特殊的 prop 进行内部处理,然后再从 props 对象中移除它们。

传统的 JSX 运行时 createElement 函数不仅作为编译器的目标,同时也是一个公共 API,可以手动调用。这意味着我们不能确保传递给 createElementprops 对象在传递后不会被用户空间的代码修改。为了确保 props 对象的稳定性和一致性,JSX 运行时选择了克隆传入的对象。

React 19

随着 React 的不断进步,新的 JSX 运行时机制发生了变化。它不再是一个公共 API,而是专属于编译器的目标。编译器在传递 props 时,总是创建一个新的内联对象。除了保留的 prop 名称外,克隆 props 的必要性大大降低。

在 React 19 中,我们见证了进一步的改进。ref 不再作为保留的 prop 名称,而 key 仅在将其展开到元素上时才会被特殊处理。

如果 key 是静态定义的,编译器会将其作为单独的参数传递给 jsx 函数,而不是作为 props 对象的一部分。克隆 props 对象的唯一剩余原因变得更加罕见,即当 key 被展开到元素上时,尽管这种情况会引发警告。

在未来的 React 版本中,我们计划进一步优化这一机制。我们将不再从 props 对象中删除展开的 key,但仍然会发出警告,以提醒开发者注意潜在的问题。

这样我们就可以直接传递原始的 props 对象,减少不必要的克隆操作。这一改进带来的预期影响是 JSX 元素创建速度的显著提升。

在大多数应用中,JSX 元素的创建占据了渲染过程的重要部分,因此这一优化将直接提升应用的性能。无论是用户界面的响应速度,还是整体应用的流畅度,都将得到显著的提升。

总结

React 19 带来了革命性的 JSX 元素创建速度提升。升级到最新版本,你将能够享受到更快的应用性能,为你的用户带来更加流畅和高效的体验。不要错过这一重要的性能优化机会,让 React 19 为你的应用注入新的活力!


http://www.ppmy.cn/devtools/10277.html

相关文章

uniapp微信小程序分包

一、创建分包文件夹subPack 二、将页面文件放入分包文件夹中 启动页面和导航tabBar页面不要放入分包文件夹中 三、配置pages.json 四、效果

Dubbo SPI 和 Java SPI 区别

JDK SPI JDK 标准的 SPI 会一次性加载所有的扩展实现,如果有的扩展吃实话很耗时,但也没用上,很浪费资源。所以只希望加载某个的实现,就不现实了 DUBBO SPI 1: 对 Dubbo 进行扩展,不需要改动 Dubbo 的源码 …

Linux:安装及管理程序

Linux:安装及管理程序 应用程序基础 应用程序与系统命令的关系 角色系统命令应用程序文件位置般在/bin和/sbin目录中,或为Shell内部指令通常在/usr/bin、/usr/sbin 和/usr/local/bin、/usr/local/sbin目录中主要用途完成对系统的基本管理工作&#xf…

世界读书日:探索阅读的多样性样性——漫画、图解、图形化立体图书

在当今信息爆炸的时代,阅读已经不再局限于传统的书籍形式。随着科技的发展和文化的多样化,人们可以通过多种形式来获取知识和享受阅读的乐趣。从漫画、图解到图形化立体图书,每一种形式都有其独特的魅力,适合不同类型的读者和学习…

MySQL 基础使用

文章目录 一、Navicat 工具链接 Mysql二、数据库的使用1.常用数据类型2. 建表 create3. 删表 drop4. insert 插入数据5. select 查询数据6. update 修改数据7. delete 删除记录truncate table 删除数据 三、字段约束字段1. 主键 自增delete和truncate自增长字段的影响 2. 非空…

【项目部署-apache】windows系统下apache部署django+channels

一、系统环境 1、原生的python3.8.5(默认安装,不更改安装目录),不要使用Anaconda做虚拟环境。 2、在windows系统下需要,mod_wsgi 模块。 创建虚拟环境:(在当前目录下创建名为 gzgs_alert 的虚拟环境) py…

Linux 终止进程命令—sudo kill -9 <进程号>

一、查找占用端口的进程&#xff1a;使用以下命令找到占用了该端口的进程&#xff1a; sudo lsof -i :<端口号> 该命令将显示占用该端口的进程的详细信息。 二、结束占用端口的进程&#xff1a;根据上一步得到的进程信息&#xff0c;使用以下命令结束该进程&#xff1a…

Web端Webrtc,SIP,RTSP/RTMP,硬件端,MCU/SFU融合视频会议系统方案分析

Web端视频融合&#xff0c;会议互通已经是视频会议应用的大趋势&#xff0c;一是目前企业有大量的老视频会议硬件设&#xff0c;二新业务又需要Web端支持视频会议监控直播需求&#xff0c;迫切需要一个融合对接的方案&#xff0c;即能把老的设备用起来&#xff0c;又能对接新的…