使用有什么好处吗useMemo
(例如,对于密集的函数调用)而不是使用组合useEffect
and useState
?
这里有两个定制的钩子,乍一看它们的工作原理完全相同,此外useMemo
的返回值为null
在第一次渲染时:
useEffect 和 useState
import { expensiveCalculation } from "foo";
function useCalculate(someNumber: number): number | null {
const [result, setResult] = useState<number | null>(null);
useEffect(() => {
setResult(expensiveCalculation(someNumber));
}, [someNumber]);
return result;
}
useMemo
import { expensiveCalculation } from "foo";
function useCalculateWithMemo(someNumber: number): number {
return useMemo(() => {
return expensiveCalculation(someNumber);
}, [someNumber]);
};
两者都计算每次参数的结果someNumber
变化,记忆在哪里useMemo
踢进去?
The useEffect
and setState
每次更改都会导致额外的渲染:第一个渲染将“落后于”过时的数据,然后它会立即使用新数据对额外的渲染进行排队。
假设我们有:
// Maybe I'm running this on a literal potato
function expensiveCalculation(x) { return x + 1; };
让我们假设x
最初为 0:
- The
useMemo
版本立即呈现1
.
- The
useEffect
版本呈现null
,然后在组件渲染后,效果运行,更改状态,并将新渲染排队1
.
那么如果我们改变x
to 2:
- The
useMemo
运行并且3
被渲染。
- The
useEffect
版本运行并渲染1
再次,然后效果触发并且组件以正确的值重新运行3
.
就频率而言expensiveCalculation
运行时,两者具有相同的行为,但是useEffect
版本导致两倍的渲染,这由于其他原因对性能不利。
另外,useMemo
IMO,版本更干净,更具可读性。它不会引入不必要的可变状态,并且移动部件更少。
所以你最好只使用useMemo
here.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)