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