很多文章说 useCallback 的好处就是缓存一个函数,这样子组件如果从父组件收到一个函数的 props ,就没有变化, 子组件就不需要重新 render 。。。
我的疑问是,父组件更新的时候,子组件不就自动 render 了? 这样的优化有啥意义?
1
coolzjy 2021-12-25 20:35:37 +08:00
> 父组件更新的时候,子组件不就自动 render 了
当然不是这样,子组件 props 不变的情况下是不会重新渲染的。 |
3
cutemurphy2000 OP @coolzjy 那还是有前置条件的吖
|
4
noe132 2021-12-25 23:57:32 +08:00 via Android
useCallback = (fn, deps) => useMemo(() => fn, deps)
|
5
ericls 2021-12-26 08:53:47 +08:00
parent 传入的 props 或者 自己的 state 变的时候,function body 肯定是要重头执行一次的,如果不用 memoization 的话,那每一次定义的 function 都是一个全新的 function
|
6
meteor957 2021-12-26 10:09:10 +08:00 via Android 1
子组件没有 memo 的话,这种优化确实没有意义。
但 useCallback 不止是这一个作用。假设某个函数被当作依赖传给 useEffect ,并且没有被 useCallback 缓存的话,很有可能造成渲染死循环。 |
7
shabbyin 2021-12-26 10:27:20 +08:00
useCallback 等于函数的 useMemo
|
8
mirone 2021-12-26 13:10:28 +08:00
|
10
DICK23 2021-12-27 14:34:52 +08:00
这个基本就是 useMemo 的变形,其实也没啥用,后期 API 都会被改掉
|