当前位置: 首页 > news >正文

react18更新哪些东西

React 18 是 React 的一个重要版本,于 2022 年 3 月正式发布,它为 React 带来了许多关键的更新和特性,特别是为了支持 并发渲染(Concurrent Rendering)。以下是 React 18 的核心更新内容:


🚀 核心特性更新

1. ✅ 自动批处理(Automatic Batching)

  • React 18 之前,只有在 React 控制下(如事件处理函数中)多次 setState 才会批处理更新。

  • 在 React 18 中,即使在 setTimeoutPromise.then、原生事件或其他异步操作中,也会批处理多个状态更新,从而减少重新渲染次数。

// React 18
setTimeout(() => {setCount(c => c + 1);setFlag(f => !f);
}, 1000);
// 只触发一次 render

2. ⏱️ 并发特性(Concurrent Features)

  • 并发渲染是 React 18 最大的变革。它允许 React 在后台准备多个 UI 状态,然后根据需要显示出来。

  • 启用并发特性是 可选的,通过 <StrictMode> + createRoot 使用:

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

并发模式不是另一个模式,而是一个能力。它让 React 更加灵活高效地调度工作。


3. 🧩 <Suspense> 支持服务端渲染和更多异步场景

  • 在 React 18 中,Suspense 不再局限于 code-splitting,而可以用于更多异步 UI 加载场景,包括服务端渲染。

<Suspense fallback={<Loading />}><SomeAsyncComponent />
</Suspense>

4. ⏳ startTransition API

  • 用于将“非紧急更新”标记为可中断的 transition,避免卡顿。

import { startTransition } from 'react';const handleInput = (e) => {const nextValue = e.target.value;// 不紧急的更新startTransition(() => {setSearchQuery(nextValue);});
};

React 会优先渲染紧急更新(如输入框变化),延迟处理不紧急的内容(如渲染搜索结果)。


5. 🔁 新 Hook:useTransition / useDeferredValue

  • useTransition: 和 startTransition 配套,用于标记“低优先级”的状态更新。

const [isPending, startTransition] = useTransition();startTransition(() => {setValue(inputValue);
});
  • useDeferredValue: 推迟传入值的更新,用于列表、表格等 UI 优化。

const deferredValue = useDeferredValue(inputValue);

6. 🧵 React 18 SSR 改进

React 18 引入了新的 流式服务端渲染 API

  • renderToPipeableStream(Node.js)

  • 支持边渲染边传输(streaming),更快的首屏渲染。

import { renderToPipeableStream } from 'react-dom/server';

7. 🧪 并发特性向下兼容,渐进增强

  • 你可以按需在应用中逐步引入并发特性。

  • 默认行为和 React 17 保持一致,避免破坏现有功能。


📦 升级注意点

  • 使用 createRoot 替代 ReactDOM.render

// React 17
ReactDOM.render(<App />, document.getElementById('root'));// React 18
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<App />);
  • 第三方库是否兼容 React 18(特别是并发模式)可能需要确认。

  • 某些行为可能有轻微变化,如状态更新时机。


🔮 总结:React 18 带来了什么?

特性描述
✅ 自动批处理提升性能,减少重复渲染
🧠 并发渲染能力更灵活的 UI 响应能力
🌀 startTransition / useTransition提高响应速度,避免卡顿
🧵 流式 SSR更快首屏,更强 SEO 支持
🧩 更强的 Suspense 支持支持异步数据和懒加载组件
🔧 createRoot开启并发特性的入口

http://www.dtcms.com/a/293798.html

相关文章:

  • 5G时代PCB设计新突破:猎板三大创新技术重塑高频信号完整性
  • ES6 标签模板:前端框架的灵活利器
  • 2025年电赛--电源题赛前押题
  • LeetCode 460:LFU 缓存
  • LeetCode热题100--383
  • 时序数据库主流产品概览
  • 基于单片机排队叫号系统设计
  • 自动化运维:从脚本到DevOps的演进
  • Win10_Qt6_C++_YOLO推理 -(1)MingW-opencv编译
  • 人工智能——Opencv图像色彩空间转换、灰度实验、图像二值化处理、仿射变化
  • 腾讯iOA:企业软件合规与安全的免费守护者
  • 建数仓该选大SQL还是可视化ETL平台?
  • kotlin基础【2】
  • kettle 8.2 ETL项目【一、初始化数据库及介绍】
  • UniappDay01
  • Django学习之旅--第13课:Django模型关系进阶与查询优化实战
  • 傅里叶转换(机器视觉方向)
  • Oracle19c HINT不生效?
  • Unreal5从入门到精通之使用 Python 编写虚幻编辑器脚本
  • WWDC 25 给自定义 SwiftUI 视图穿上“玻璃外衣”:最新 Liquid Glass 皮肤详解
  • 设备虚拟化——软堆叠技术
  • CNN正则化:Dropout与DropBlock对比
  • iOS开发 Swift 速记7:结构体和类
  • ToBToC的定义与区别
  • js面试题 高频(1-11题)
  • split() 函数在 Java、JavaScript 和 Python 区别
  • HUAWEI Pura80系列机型参数对比
  • 自学嵌入式 day33 TCP、HTTP协议(超文本传输协议)
  • MySQL深度理解-深入理解MySQL索引底层数据结构与算法
  • Hexo - 免费搭建个人博客03 - 将个人博客托管到github,个人博客公开给大家访问