React 18新特性介绍

React 18是React团队于2022年发布的一个重要版本,它引入了多项改进和新特性,在提升性能的同时也带来了一些使用上的变化。本文将全面介绍React 18的主要新特性,包括并发渲染、API更新、浏览器兼容性等重要内容,并通过代码示例说明其使用场景。

1. 并发渲染(Concurrent Rendering)

1.1. 并发模式基础

import { createRoot } from 'react-dom/client';// React 18新渲染API
const root = createRoot(document.getElementById('root'));
root.render(<App />);

变化说明:新的createRootAPI取代了原有的ReactDOM.render,这是启用所有并发特性的前提。

1.2. 过渡更新(Transition)

function SearchBox() {const [isPending, startTransition] = useTransition();const handleChange = (e) => {// 紧急更新:立即响应用户输入setInputValue(e.target.value);// 非紧急更新:标记为过渡更新startTransition(() => {setSearchQuery(e.target.value);});};return (<div>{isPending && <Spinner />}<SearchResults query={searchQuery} /></div>);
}

场景说明:适合搜索框、标签页切换等需要区分优先级更新的场景。

2. 自动批处理与手动控制

2.1. 自动批处理

// 所有场景下的更新都会被自动批处理
function handleClick() {setCount(c => c + 1);  // 不会立即重渲染setFlag(f => !f);      // 与上面的更新一起批处理
}

2.2. 手动控制:flushSync

import { flushSync } from 'react-dom';function handleClick() {// 立即执行更新flushSync(() => {setCount(c => c + 1);});// DOM此时已更新flushSync(() => {setFlag(f => !f);});
}

场景说明:flushSync适用于需要同步读取DOM的场景,如表单验证、动画触发等。

3. 严格模式(Strict Mode)更新

React 18增强了严格模式的行为:

<StrictMode><App />
</StrictMode>

新增行为

1. 组件会模拟卸载后重新挂载,测试effect清理函数是否正确;

2. 开发环境下会重复调用以下函数:

(1). 组件函数体

(2). 初始化state

(3). reducer函数

(4). 某些生命周期方法

场景说明:帮助发现组件中潜在的副作用问题,建议开发环境始终启用。

4. 新的API与语法变化

4.1. useId

const id = useId();  // 生成形如":r1:"的稳定ID

4.2. 组件可返回undefined

function Component() {// React 17会报错,React 18允许return undefined;
}

变化说明:现在组件可以安全返回null或undefined,与React元素类型保持一致。

5. 浏览器兼容性

React 18仅支持现代浏览器

1. 不再支持IE11;

2. 主要支持Chrome、Firefox、Edge、Safari的最近两个版本;

3. 需要Promise、Symbol、Object.assign等ES6特性;

兼容方案

<!-- 为旧版浏览器添加polyfill -->
<script src="https://cdn.polyfill.io/v3/polyfill.min.js"></script>

6. 服务端渲染改进

6.1. 流式SSR

const { pipe } = renderToPipeableStream(<App />, {onShellReady() {pipe(response);},onError(error) {console.error(error);response.statusCode = 500;pipe(response);}
});

6.2. 选择性Hydration

<Suspense fallback={<Spinner />}><Comments />
</Suspense>

场景说明:大型页面可以优先hydrate关键部分,非关键内容延迟处理。

7. 升级注意事项

1. TypeScript类型更新:需要@types/react和@types/react-dom更新到18.x版本;

2. 测试库适配:React Testing Library需要v13+版本;

3. 副作用处理:严格模式下的双重调用可能暴露effect清理问题;

4. CSS-in-JS方案:部分库需要更新以支持并发渲染;

8. 实际应用建议

1. 渐进式升级策略

// 可保留旧版渲染API(不启用新特性)
ReactDOM.render(<App />, root);// 逐步迁移到新版API
const root = createRoot(document.getElementById('root'));
root.render(<App />);

2. 性能优化组合

function App() {return (<Suspense fallback={<Loader />}><UserProfile /><startTransition><Comments /></startTransition></Suspense>);
}

3. 错误边界处理

class ErrorBoundary extends React.Component {componentDidCatch(error) {// React 18会提供更详细的错误信息logError(error);}
}

9. 结语

React 18通过并发渲染等创新带来了显著的性能提升,同时也引入了一些重要的变化和限制。开发者需要特别注意:

1. 现代浏览器支持要求;

2. 严格模式的新行为;

3. 状态批处理的变化;

4. 新API的适用场景;

合理运用过渡更新、Suspense等特性,可以构建出更加流畅的用户体验。建议在开发环境充分测试严格模式的警告,并在生产环境利用流式SSR等改进提升性能。

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

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

相关文章

设计模式——面向对象设计六大原则

摘要 本文详细介绍了设计模式中的六大基本原则&#xff0c;包括单一职责原则、开放封闭原则、里氏替换原则、接口隔离原则、依赖倒置原则和合成复用原则。每个原则都通过定义、理解、示例三个部分进行阐述&#xff0c;旨在帮助开发者提高代码的可维护性和灵活性。通过具体代码…

使用 So-VITS-SVC 实现明星声音克隆与视频音轨替换实战全流程

本文展示如何使用开源项目 so-vits-svc 实现声音克隆与视频音轨替换流程&#xff0c;适用于 AI 音频工程、声音合成等学习场景。所述内容仅限技术交流&#xff0c;禁止用于非法用途。 一、项目背景 此项目采用 so-vits-svc 4.1 开源框架&#xff0c;实现了“用明星声音替换视频…

【学习记录】深入解析 AI 交互中的五大核心概念:Prompt、Agent、MCP、Function Calling 与 Tools

&#x1f4cc; 引言 随着大语言模型&#xff08;LLM&#xff09;的发展&#xff0c;AI 已经不再只是“回答问题”的工具&#xff0c;而是可以主动执行任务、调用外部资源、甚至构建完整工作流的智能系统。 为了更好地理解和使用这些能力&#xff0c;我们需要了解 AI 交互中几…

纹理压缩格式优化

🎯 Unity 项目纹理压缩格式优化终极指南 ——不同平台、不同手机型号,如何正确选择 🧩 什么是纹理压缩(Texture Compression)? Texture压缩 = 减小显存占用,提升加载速度,减轻GPU负担纹理是游戏中最大资源,占用50%+内存正确压缩:减少GPU Bandwidth,提高渲染性能错…

Docker轻松搭建Neo4j+APOC环境

Docker轻松搭建Neo4jAPOC环境 一、简介二、Docker部署neo4j三、Docker安装APOC插件四、删除数据库/切换数据库 一、简介 Neo4j 是一款高性能的 原生图数据库&#xff0c;采用 属性图模型 存储数据&#xff0c;支持 Cypher查询语言&#xff0c;适用于复杂关系数据的存储和分析。…

NGINX `ngx_stream_core_module` 模块概览

一、模块定位与功能 通用 TCP/UDP 代理 支持同时处理 TCP 和 UDP 流量&#xff0c;透明转发请求到后端服务器组&#xff08;upstream&#xff09;。可作为四层负载均衡&#xff0c;根据客户端 IP、权重、最少连接等策略将连接分发给后端。 预读&#xff08;preread&#xff09…

JVM类加载高阶实战:从双亲委派到弹性架构的设计进化

前言 作为Java开发者&#xff0c;我们都知道JVM的类加载机制遵循"双亲委派"原则。但在实际开发中&#xff0c;特别是在金融支付、插件化架构等场景下&#xff0c;严格遵循这个原则反而会成为系统扩展的桎梏。本文将带你深入理解双亲委派机制的本质&#xff0c;并分享…

MATLAB | 绘图复刻(十九)| 轻松拿捏 Nature Communications 绘图

hello这次真的是好久不见了&#xff0c;前段时间确实太忙&#xff0c;后台都忙到没时间看&#xff0c;对不住大家的热情&#xff0c;这期复刻两个 Nature Communications 绘图&#xff0c;主要都和弦图有关&#xff1a; 原图 1 复刻图 1 原图 2 复刻图 2 这次绘图使用我自己开…

群晖NAS如何在虚拟机创建飞牛NAS

套件中心下载安装Virtual Machine Manager 创建虚拟机 配置虚拟机 飞牛官网下载 https://iso.liveupdate.fnnas.com/x86_64/trim/fnos-0.9.2-863.iso 群晖NAS如何在虚拟机创建飞牛NAS - 个人信息分享

设计模式(代理设计模式)

代理模式解释清楚&#xff0c;所以如果想对一个类进行功能上增强而又不改变原来的代码情况下&#xff0c;那么只需要让这个类代理类就是我们的顺丰&#xff0c;对吧?并行增强就可以了。具体增强什么?在哪方面增强由代理类进行决定。 代码实现就是使用代理对象代理相关的逻辑…

Flask + ECharts+MYSQL全球贸易数字化大屏

核心功能: 全球贸易热力图:展示中国与各国的贸易关系强度 贸易指标卡片:实时显示贸易总额、投资额等关键指标 贸易伙伴排名:展示中国前10大贸易伙伴 贸易类型分布:展示各类商品的贸易占比 全球实时动态:滚动显示全球贸易、投资等实时事件 技术亮点: 使用WebSocket实现实…

wpf Behaviors库实现支持多选操作进行后台绑定数据的ListView

<ListView ItemsSource"{Binding SchemeItems}" SelectionMode"Extended" VerticalAlignment"Stretch" HorizontalAlignment"Stretch"><ListView.ContextMenu><ContextMenu><MenuItem Header"删除" …

50个JAVA常见代码大全:学完这篇从Java小白到架构师

50个JAVA常见代码大全&#xff1a;学完这篇从Java小白到架构师 Java&#xff0c;作为一门流行多年的编程语言&#xff0c;始终占据着软件开发领域的重要位置。无论是初学者还是经验丰富的程序员&#xff0c;掌握Java中常见的代码和概念都是至关重要的。本文将列出50个Java常用…

【Linux手册】冯诺依曼体系结构

目录 前言 五大组件 数据信号 存储器&#xff08;内存&#xff09;有必要吗 常见面试题 前言 冯诺依曼体系结构是当代计算机基本架构&#xff0c;冯诺依曼体系有五大组件&#xff0c;通过这五大组件直观的描述了计算机的工作原理&#xff1b;学习冯诺依曼体系可以让给我们更…

10_聚类

描述 聚类&#xff08;clustering&#xff09;是将数据集划分成组的任务&#xff0c;这些组叫作簇&#xff08;cluster&#xff09;。其目标是划分数据&#xff0c;使得一个簇内的数据点非常相似且不同簇内的数据点非常不同。与分类算法类似&#xff0c;聚类算法为每个数据点分…

【SSM】SpringBoot学习笔记1:SpringBoot快速入门

前言&#xff1a; 文章是系列学习笔记第9篇。基于黑马程序员课程完成&#xff0c;是笔者的学习笔记与心得总结&#xff0c;供自己和他人参考。笔记大部分是对黑马视频的归纳&#xff0c;少部分自己的理解&#xff0c;微量ai解释的内容&#xff08;ai部分会标出&#xff09;。 …

国产高性能pSRAM选型指南:CSS6404LS-LI 64Mb QSPI伪静态存储器

一、芯片基础特性 核心参数 容量 &#xff1a;64Mb&#xff08;8M 8bit&#xff09;电压 &#xff1a;单电源供电 2.7-3.6V &#xff08;兼容3.3V系统&#xff09;接口 &#xff1a;Quad-SPI&#xff08;QPI/SPI&#xff09;同步模式封装 &#xff1a; SOP-8L (150mil) &#…

Cilium动手实验室: 精通之旅---4.Cilium Gateway API - Lab

Cilium动手实验室: 精通之旅---4.Cilium Gateway API - Lab 1. 环境准备2. API 网关--HTTP2.1 部署应用2.2 部署网关2.3 HTTP路径匹配2.4 HTTP头匹配 3. API网关--HTTPS3.1 创建TLS证书和私钥3.2 部署HTTPS网关3.3 HTTPS请求测试 4. API网关--TLS 路由4.1 部署应用4.2 部署网关…

20250605在微星X99主板中配置WIN10和ubuntu22.04.6双系统启动的引导设置

rootrootrootroot-X99-Turbo:~$ sudo apt-get install boot-repair rootrootrootroot-X99-Turbo:~$ sudo add-apt-repository ppa:yannubuntu/boot-repair rootrootrootroot-X99-Turbo:~$ sudo apt-get install boot-repair 20250605在微星X99主板中配置WIN10和ubuntu22.04.6双…

MyBatis之测试添加功能

1. 首先Mybatis为我们提供了一个操作数据库的会话对象叫Sqlsession&#xff0c;所以我们就需要先获取sqlsession对象&#xff1a; //加载核心配置文件 InputStream is Resources.getResourceAsStream("mybatis-config.xml"); //获取sqlSessionFactoryBuilder(是我…