React 18 升级指南,超简单

简介: React 18 升级指南,超简单


React 18是React一系列主要版本中的最新版本。有了它,你可以访问:新的特性,新的useId, useSyncExternalStore,和useDeferredValue钩子,以及新的startTransition API

虽然React 18还不是一个稳定的版本,但是测试一下你的应用还是很有用的。

与之前的React主要版本一样,React 18对于大多数应用来说都是一个相当简单的迁移。

虽然Strict Mode的一些变化可能会影响你的应用,自动批处理可能会引入一些新的边缘情况,但它们只会影响那些没有正确遵循React规则的应用。

除了这些考虑,让我们升级!

安装

首先,安装React 18:

npm i react@18.0.0-rc.0 react-dom@18.0.0-rc.0

or:

yarn add react@18.0.0-rc.0 react-dom@18.0.0-rc.0

如果你正在使用Create React App,你可能也想升级到最新的v5版本,使用:

yarn add react-scripts@5

然后,确保升级任何可能依赖React的依赖项。

例如,将React Redux升级到v8或SWR升级到1.1.0

升级 render 方法

在你安装了React 18之后,你可能会在应用程序运行时收到一个错误:

警告:ReactDOM。React 18不再支持 render。使用createRoot代替。在你切换到新的API之前,你的应用会表现得像在运行React 17一样。了解更多信息:https://reactjs.org/link/switch-to-createroot

这是因为在之前的React 17和之前,你会有一个文件——通常叫做index.js或index.ts ’ , 包含以下代码:

const rootElement = document.getElementById("root");

虽然这段代码将继续在这个版本中发挥作用,但它不允许你利用React 18的大部分新特性。此外,它将在React的未来版本中被删除。

要解决此问题,请将此代码替换为以下代码:

const rootElement = document.getElementById("root");
ReactDOM.createRoot(rootElement).render(
  <App />
);

完成后,你应该能够通过{React.version}来验证你使用的React版本。

示例:

<html>
  <head>
    <meta charset="UTF-8" />
    <title>Hello World</title>
    <script src="https://unpkg.com/react@18.0.0-rc.0/umd/react.production.min.js"></script>
    <script src="https://unpkg.com/react-dom@18.0.0-rc.0/umd/react-dom.production.min.js"></script>
    <script src="https://unpkg.com/@babel/standalone@7.13.12/babel.min.js"></script>
  </head>
  <body>
    <div id="root"></div>
    <script type="text/jsx">
      ReactDOM.createRoot(
        document.getElementById('root')
      ).render(
        <h1>Hello, React {React.version}!</h1>,
      );
    </script>
  </body>
</html>

总结

正如承诺的那样,React 18的更新非常简单!大多数应用程序应该能够在没有太多问题的情况下进行升级。

如果你在你的迁移过程中遇到问题,你正在使用StrictMode,试着暂时删除它,看看你是否遇到任何问题。React 18引入了一些可能会影响一些应用的变化。

最后,希望你喜欢新的 React 特性!



相关文章
|
11月前
|
前端开发 开发者
|
监控 前端开发
React Router3到5 升级小记
现在都 React Router 5 了,你是不是还在用v3呢? 不光是你在用,我们很多项目也在用,懒得升级,感觉改动太大,升级了后谁知道会出什么问题,别没事找事。 毕竟v4是两年前的了,再不升级真的就有点说不过去了,直接拿一个小项目开刀,直接3-5吧,整体来说还好,v5版完全向下兼容react15,所以如果你的 react 是15的话没啥影响。 这里就简单的总结下,这次升级的一些内容。
92 1
React Router3到5 升级小记
|
存储 资源调度 前端开发
如何升级到 React 18发布候选版
上周 react 官网 发布了react@rc 版本,该版本是候选版本(Release Candidate),这意味API已经基本稳定,跟最终版本不会有太大差别。
220 0
|
移动开发 Dart 前端开发
React Native 迎来重大架构升级,性能将大幅提升
7 月 14 日,React Native 核心团队的 Joshua Gross 在 Twitter 说,RN 的新架构已经在 Facebook 内部落地了,并且 99%的代码已经开源。这次的架构升级“蓄谋已久”,Joshua 说他们从 2018 年 1 月就开始规划了。
444 0
React Native 迎来重大架构升级,性能将大幅提升
|
前端开发 Android开发
[React Native]升级React Native版本
React Native正式版本还没发布,但是小版本基本上每个月都更新1-2次。9月11号又更新了0.33版本,其中有两个增强功能正好是项目中用到的. 添加Android6.0权限验证API Add JS library for requesting Android M Permissions (0fb2ccf) - @cmcewen Android对话框可以设置ca
1122 0
|
6天前
|
设计模式 前端开发 数据可视化
【第4期】一文了解React UI 组件库
【第4期】一文了解React UI 组件库
138 0
|
6天前
|
存储 前端开发 JavaScript
【第34期】一文学会React组件传值
【第34期】一文学会React组件传值
35 0
|
6天前
|
前端开发
【第31期】一文学会用React Hooks组件编写组件
【第31期】一文学会用React Hooks组件编写组件
37 0
|
6天前
|
存储 前端开发 JavaScript
【第29期】一文学会用React类组件编写组件
【第29期】一文学会用React类组件编写组件
39 0
|
6天前
|
资源调度 前端开发 JavaScript
React 的antd-mobile 组件库,嵌套路由
React 的antd-mobile 组件库,嵌套路由
49 0