前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[译] 为何 React 18 中 useEffect 会运行两次?

[译] 为何 React 18 中 useEffect 会运行两次?

作者头像
江米小枣
发布2022-08-30 14:55:43
1.8K0
发布2022-08-30 14:55:43
举报
文章被收录于专栏:云前端云前端

原文:https://flaviocopes.com/react-useeffect-two-times/

在 2022 年 3 月发布的 React 18 的发布公告中,数量可观的新特性扑面而来。而对 useEffect() 的默认行为的改变,可能就此被淹没了。

如果你的应用在更新到 React 18 之后行为迥异,或许正是因为 useEffect() 默认变为被运行 2 次了

虽然这种情况只发生在 development mode 中,但无疑每位开发者都会遇到。

另一个限制条件是 只在 strict mode 发生,但这同样是用 create-react-app 或 Next.js 所构建应用的默认选项。

事情就是这么个事情,所以不用紧张是不是代码出了什么问题 -- React 的现状如此。

唯一避免这种行为的方法就是 禁用 strict mode;鉴于严格模式的重要性,这毕竟是个你能修复这种改变引入的任何问题之前临时的变通之策。

在 Next.js 中,可以在 next.config.js 文件里增加这个选项:

代码语言:javascript
复制
reactStrictMode: false

create-react-app 创建的应用里,可以把 index.js 文件里的 StrictMode 高阶组件去除:

比如从这样:

代码语言:javascript
复制
import React, { StrictMode } from 'react';
import { createRoot } from 'react-dom/client';

import App from './App';

const rootElement = document.getElementById('root');
const root = createRoot(rootElement);

root.render(
  <StrictMode>
    <App />
  </StrictMode>
);

改为:

代码语言:javascript
复制
import React from 'react';
import { createRoot } from 'react-dom/client';

import App from './App';

const rootElement = document.getElementById('root');
const root = createRoot(rootElement);

root.render(
  <App />
);
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-06-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 云前端 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档