Hooks - useMemo & useCallBack & React.memo

bestCindyIP属地: 贵州
字数 384

useMemo & useCallBack

在 React 中,当父组件发生变化的时候,子组件会重新渲染一遍,但是在子组件中,有些事件我们并不想让它执行

在 class component 中有 shouldComponentUpdate 中可以进行一个判断

在 function component 中,可以用 useMemouseCallback

这两个 hooks 解决的是一个重复渲染的问题

useCallbackuseMemo 的参数跟 useEffect 一致,他们之间最大的区别是 useEffect 会用于处理副作用,而前两个 hooks不能

useCallbackuseMemo 的区别在于,useCallback 返回一个 function,useMemo 返回一个 value

换句话说,useCallbackuseMemo 可以做一个缓存,前者缓存一个引用,后者缓存一个值

也就是 useCallback(fn, deps)useMemo(() => fn, deps) 是等价的

关于用法

useCallback

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

当 [a. b] 不变的时候 memorizedCallback 的引用不变,useCallback 的第一个入参函数会被缓存,从而达到性能优化的目的

useMemo

const memorizedValue = useMemo(() => computedExpensiveValue(a, b), [a, b]);

当 [a, b] 不变的时候 memorizedValue 的值不变,useMemo 的第一个入参函数不会执行,从而达到节省计算量的目的

React.memo

React.memo 是一个高阶组件,功能类似于 React.PureComponent

默认情况下,memo 会对复杂的对象做一个浅层的对比,如果想要控制对比过程,可以将自定义比较的函数通过第二个参数传入来实现

function MyComponent(props) {
    /* 使用 props 渲染 */
}

function areEqual(prevProps, nextProps) {
    /*
    ...
    */
}

export default React.memo(MyComponent, areEqual);

注意:React.memo 比较的是 propsshouldComponentUpdate 比较的是 stateprops

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
0人点赞
总资产2共写了5.4W字获得19个赞共13个粉丝

推荐阅读更多精彩内容

  • 使用React Hooks有什么优势? 什么是hookshook 是一些可以让你在函数组件里面钩入react st...
    Lyan_2ab3阅读 371评论 0 1
  • 先来看看类组件的生命周期Class 组件的生命周期 相对以前较老的生命周期,新增了 getDerivedState...
    CondorHero阅读 579评论 0 1
  • 1、什么是Hooks 在不编写 class 的情况下使用 state 以及其他的 React 特性(生命周期) 规...
    郭仙人不是闲人阅读 476评论 0 0
  • 推荐指数: 6.0 书籍主旨关键词:特权、焦点、注意力、语言联想、情景联想 观点: 1.统计学现在叫数据分析,社会...
    Jenaral阅读 5,749评论 0 5
  • 城空了,有树长出来 我的城死了 铸起它的人,杀死它的人 不愿因为这件事而骄傲 一座城的终结 永远因为终结这件事而显...
    于十六阅读 2,885评论 6 17