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

ReactDOM 18版本 使用createRoot 替换render详解

概述

React 18 提供了两个 root API,被称之为 Legacy Root API 和 New Root API:

Legacy Root API:是指之前版本的 root API ReactDOM.render,它将创建一个以 “legacy” 模式运行的 root,其工作方式与 React 17 完全相同。我们会给这个 API 添加一个警告,来说明它将要被弃用并建议切换到 New Root API。
New Root API:新的 root API 是 ReactDOM.createRoot。它可以在 React 18 中创建一个 root,并支持 React 18 中支持的所有新特性。

注意:

Legacy Root API是为了避免用户升级到 React 18 出现问题。React官方向旧的 root API 添加了一个警告,建议使用新 API,并且Eslit会有error类型的错误拦截。

将 ReactDOM.render 替换为 ReactDOM.createRoot 是 React 18 中的一个重要改动,带来了多项改进和新特性。以下是一些主要的好处:

1. 并发特性(Concurrent Features)

自动批处理

React 18 引入了自动批处理(Automatic Batching),它可以将多个状态更新合并为一次渲染,从而提高性能。使用 createRoot 可以自动启用这项功能。

并发渲染(Concurrent Rendering)

并发渲染使得 React 可以在不阻塞主线程的情况下准备新的 UI 更新。当用户进行交互时,React 可以更快地响应和更新界面。createRoot 支持并发渲染,而 ReactDOM.render 不支持。

2. startTransition API

使用 createRoot 可以启用 startTransition API,用于标记低优先级更新。这对于优化性能、避免界面卡顿非常有帮助。


import { startTransition } from 'react';// Example usage
startTransition(() => {setState(newState);
});

3. useDeferredValue 和 useTransition Hook

这些新的 Hook 提供了更灵活的方式来处理异步状态更新和延迟渲染。createRoot 支持这些特性,而 ReactDOM.render 不支持。

4. 流畅的 Suspense 支持

React 18 中的 Suspense 特性得到了增强,提供了更好的加载状态处理和流畅的用户体验。createRoot 完全支持这些改进。

5. 改进的 SSR(Server-Side Rendering)

React 18 提供了改进的服务器端渲染功能,包括流式渲染和并发特性。使用 createRoot 使得客户端和服务端渲染的同步更为流畅。

6. 更好的错误处理

React 18 改进了错误处理机制,使得在开发和生产环境中更容易捕获和处理渲染错误。使用 createRoot 可以更好地利用这些改进。

升级前提:安装最新的 React 和 ReactDOM

确保你已经安装了最新版本的 React 和 ReactDOM。

npm install react@latest react-dom@latest

代码示例:如何使用 createRoot
下面是一个简单的示例,展示了如何将 ReactDOM.render 替换为 ReactDOM.createRoot

使用 ReactDOM.render 的旧代码:

import React from 'react';
import ReactDOM from 'react-dom';
import App from './App';ReactDOM.render(<React.StrictMode><App /></React.StrictMode>,document.getElementById('root')
);

使用 ReactDOM.createRoot 的新代码:

import React from 'react';
import ReactDOM from 'react-dom/client';
import App from './App';// 获取根节点
const container = document.getElementById('root');// 创建根组件
const root = ReactDOM.createRoot(container);// 渲染根组件
root.render(<React.StrictMode><App /></React.StrictMode>
);

总结

使用 ReactDOM.createRoot 取代 ReactDOM.render 是为了充分利用 React 18 的新特性和改进,包括并发渲染、更好的性能和新的 API。这些改进使得 React 应用程序在处理复杂的用户交互和大量数据更新时更加高效和流畅。

http://www.lryc.cn/news/362243.html

相关文章:

  • 【赠书活动】好书推荐—《详解51种企业应用架构模式》
  • SpringBoot启动时使用外置yml文件
  • 【开源三方库】Fuse.js:强大、轻巧、零依赖的模糊搜索库
  • vue从入门到精通(六):数据代理
  • 【C++修行之道】类和对象(二)类的6个默认成员函数、构造函数、析构函数
  • 【LeetCode热题100总结】239. 滑动窗口最大值
  • 【YOLOv9改进[Conv]】使用YOLOv10的空间通道解耦下采样SCDown模块替换部分CONv的实践 + 含全部代码和详细修改内容
  • 简单小游戏制作
  • Delphi
  • Linux的shell脚本中的比大小
  • 每日复盘-20240603
  • adb server version (22000) doesn‘t match this client (41); killing...
  • 如何使用 Connector API 将数据提取到 Elasticsearch Serverless 中
  • 体育赛事直播系统开发源码搭建
  • 使用Jmeter进行性能测试
  • AI技术的发展,会让你工作轻松吗
  • Spring-DI入门案例
  • ubuntu18.04 报错:fatal error: execution
  • 开源大模型与大模型api的使用优缺点
  • 小红书前端2轮面试期望22K,全程问低代码设计
  • HIK录像机GB28181对接相机不在线问题随笔
  • stm32-DMA转运数据
  • Java编程常见问题汇总一
  • 用Unityhub安装unity2018.3.0和vuforia
  • 智汇云舟与芯瞳完成兼容适配,共建国产化生态体系
  • 「动态规划」最大子数组和
  • 【LeetCode 130. 被围绕的区域】
  • 超市管理系统设计1——基本功能设计
  • 前端性能优化总结笔记
  • 51种企业应用架构模式详解