[React Hooks] useCallback 学习

2019-10-30  本文已影响0人  小黄人get徐先生

官方文档:https://reactjs.org/docs/hooks-reference.html#usecallback

const memoizedCallback = useCallback(
  () => {
    doSomething(a, b);
  },
  [a, b],
);

useCallback 接收一个内联回调函数和一个依赖数组,返回一个记忆版本的回调函数,只有当依赖发生变化的时候,回调函数才会改变。这在将回调传递给优化的子组件时非常有用,这些组件依赖引用相等性来防止不必要的渲染(引用没有发生变化)

所以我们这里将带着一个问题阅读下面的内容:当依赖发生改变的时候,变量 memoizedCallback 的引用会发生变化吗?


下面给个代码例子:

import React, { useState, useCallback } from 'react';

const set = new Set();

function App() {

    const [num, setNum] = useState([1,2,3]);
    const [num1, setNum1] = useState([4,5,6]);

    const mCallback = useCallback(() => { console.log('callback function');return [...num, ...num1] }, []);

    return (
        <>
            <ChildrenApp num={num} num1={num1} callback={mCallback}  />
            <button onClick={() => setNum([7,8,9])} >change num</button>
            <button onClick={() => setNum1([10,11,12])} >change num1</button>
        </>
    )
}

function ChildrenApp({num, num1, callback}) {

    set.add(callback);

    console.log(set);

    return (
        <div>
            {num} - {num1} - {callback()}
        </div>
    )
}

export default App;

从上面的过程我们可以发现,set 集合里面一直只有一个函数,这说明了 callback 函数的引用没有发生变化,使用的是记忆化的版本函数。这里之所以 callback 显示的值一直是 123456 没有变化,原因在于 mCallback 函数的依赖列表为空,并没有监听 num 和 num1 的变化,所以其闭包里面的 num 和 num1 值一直分别是 123 和 456。


下面我们做点变化,修改下 mCallback 函数内容如下:

const mCallback = () => [...num, ...num1];

整个流程下来,我们可以看到 set 里面包含了三个 function,说明了每次重新渲染的时候都会重新生成 mCallback 函数并传递给子组件。


下面我们再修改修改 mCallback 函数,给它添加上依赖列表,代码如下:

const mCallback = useCallback(() => { console.log('callback function');return num }, [num]);

总结:

这里就完了吗?不,还有一个问题。为什么依赖发生变化的时候需要重新生成函数那?这里面和作用域的知识有点相关。

上一篇 下一篇

猜你喜欢

热点阅读