问题:
使用 useEffect 记录状态更改时在坐骑上,观察到该效果被触发两次。这个问题在 React 18 中遇到。
原因:
React 18 的 StrictMode 开发模式中,故意重新挂载了一次 useEffect,以确保关键组件能够弹性应对多个安装和卸载循环。 React 的目标是在这些周期中保留状态以获得更好的性能。
解决方案:
建议使用空依赖项,而不是依赖于 useEffect 的初始运行数组 ([]) 仅在第一次渲染后运行效果:
import { useState, useEffect } from "react"; const Counter = () => { const [count, setCount] = useState(0); useEffect(() => { console.log("rendered", count); }, []); return <div>...</div>; };
替代解决方案:
如果对状态的依赖性至关重要并且必须在每次渲染时进行检查,请考虑使用以下方法:
生产行为:
需要注意的是,此行为仅发生在开发模式下。在生产构建中,useEffect 每次组件挂载只会运行一次。
结论:
理解为什么 useEffect 在 React 18 中运行两次对于编写行为良好且健壮的代码至关重要反应代码。通过采用上述适当的解决方案,开发人员可以防止错误、保持状态一致性并确保高效的应用程序性能。
以上是为什么我的 useEffect Hook 在 React 18 中运行两次(以及如何修复它)?的详细内容。更多信息请关注PHP中文网其他相关文章!