学会使用useMemo和useCallback对你没坏处

简介: 学会使用useMemo和useCallback对你没坏处

这是我参与8月更文挑战的第31天,活动详情查看:8月更文挑战

什么是useMemo?

useMemo的行为类似Vue中的计算属性,可以检测某个值的变化,根据变化值计算新值。useMemo会缓存计算结果,如果检测值没有发生变化,即使组件重新渲染,也不会重新计算,此行为可以有助于避免在每个渲染上进行昂贵的计算。不要再useMemo函数中执行与渲染无关的操作。

useMemo的基本用法

function App() {
    const [bool,setBool] = useState(true);
    const [age,setAge] = useState('666');
    const result = useMemo(() => {
        console.log('检测到age发生变化');
        return age * 2; 
    },[age])
    return (
        <div>
            {age}
            {bool ? '真': '假'}
            <button onClick={() => setBool(!bool)}>点我切换布尔值</button>
            <button onClick={() => setAge(age*1 + 1)}>点我age+1</button>
            result是:{result}
        </div>
    )
}
复制代码

memo方法

memo方法可以用于性能优化,如果本组件中的数据没有发生变化,阻止组件更新,类似类组件中的PureComponent和shouldComponentUpdate.

memo方法的基本用法

function App() {
    const [count, setCount] = useState(0);
    return (
        <div>
            <Foo />
            <h1>当前求和为:{count}</h1>
            <button onClick={() => setCount(count + 1)}>点我+1</button>
        </div>
    )
}
const Foo = memo(function Foo() {
    console.log('Foo被渲染了');
    return (
        <div>这是Foo组件</div>
    )
})
复制代码

useCallback是什么?

常用于性能优化,缓存函数,使得组件重新渲染时得到相同的函数实例。

useCallback的基本用法

在这里我们需要注意的是useCallback的第一个参数时我们需要缓存的函数,第二个参数是一个数组,数组中包含的是没有变化的目标函数。

function App() {
    const [count, setCount] = useState(0);
    const resetCount = useCallback(() => setCount(0),[setCount]);
    return (
        <div>
            <Foo resetCount={resetCount}/>
            <h1>当前求和为:{count}</h1>
            <button onClick={() => setCount(count + 1)}>点我+1</button>
        </div>
    )
}
const Foo = memo(function Foo(props) {
    console.log('Foo被渲染了');
    return (
        <div>
            这是Foo组件
            <button onClick={props.resetCount}>点我归零</button>
        </div>
    )
})
复制代码

参考资料

相关文章
|
3月前
|
JavaScript 前端开发
useEffect与副作用
useEffect与副作用
27 0
|
3月前
|
缓存
UseMemo和useCallback如何提升了性能,应用场景。
UseMemo和useCallback如何提升了性能,应用场景。
|
5月前
|
前端开发 JavaScript 安全
useEffect 与 useLayoutEffect区别
useEffect 与 useLayoutEffect区别
34 0
|
3月前
|
前端开发
React中useEffect、useCallBack、useLayoutEffect
React中useEffect、useCallBack、useLayoutEffect
|
缓存 前端开发 算法
【译】你真的应该使用useMemo吗? 让我们一起来看看
- 当处理量很大时,应该使用 useMemo - 从什么时候 useMemo 变得有用以避免额外处理,阈值在很大程度上取决于您的应用程序 - 数据在处理非常低的情况下使用 useMemo
1908 0
|
8月前
|
存储 缓存 前端开发
React中useMemo和useCallback如何做到性能优化?
React中useMemo和useCallback如何做到性能优化?
|
8月前
|
JavaScript
useEffect和useLayoutEffect有什么区别
useEffect和useLayoutEffect有什么区别
|
4月前
|
缓存 前端开发 JavaScript
React.Memo和useMemo的区别?
React.Memo和useMemo的区别?
66 0
|
4月前
|
前端开发 JavaScript
useState和useReducer的区别?
useState和useReducer的区别?
36 0
|
4月前
|
存储 前端开发 JavaScript
useRef 和 useState 哪个更好?
useRef 和 useState 哪个更好?
32 1

热门文章

最新文章