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