有个 useCallback 的疑问

2021-12-25 18:36:23 +08:00
 cutemurphy2000

很多文章说 useCallback 的好处就是缓存一个函数,这样子组件如果从父组件收到一个函数的 props ,就没有变化, 子组件就不需要重新 render 。。。

我的疑问是,父组件更新的时候,子组件不就自动 render 了? 这样的优化有啥意义?

1988 次点击
所在节点    React
10 条回复
coolzjy
2021-12-25 20:35:37 +08:00
> 父组件更新的时候,子组件不就自动 render 了

当然不是这样,子组件 props 不变的情况下是不会重新渲染的。
coolzjy
2021-12-25 20:52:30 +08:00
@coolzjy 补充下,在使用 pure component / memo 的情况下是这样子的。
cutemurphy2000
2021-12-25 22:22:10 +08:00
@coolzjy 那还是有前置条件的吖
noe132
2021-12-25 23:57:32 +08:00
useCallback = (fn, deps) => useMemo(() => fn, deps)
ericls
2021-12-26 08:53:47 +08:00
parent 传入的 props 或者 自己的 state 变的时候,function body 肯定是要重头执行一次的,如果不用 memoization 的话,那每一次定义的 function 都是一个全新的 function
meteor957
2021-12-26 10:09:10 +08:00
子组件没有 memo 的话,这种优化确实没有意义。

但 useCallback 不止是这一个作用。假设某个函数被当作依赖传给 useEffect ,并且没有被 useCallback 缓存的话,很有可能造成渲染死循环。
shabbyin
2021-12-26 10:27:20 +08:00
useCallback 等于函数的 useMemo
mirone
2021-12-26 13:10:28 +08:00
tousfun
2021-12-26 19:14:17 +08:00
@mirone 好家伙,大佬的博客直接用英语写的?
DICK23
2021-12-27 14:34:52 +08:00
这个基本就是 useMemo 的变形,其实也没啥用,后期 API 都会被改掉

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/824415

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX