0


react简单入门--常用hook中useMemo的使用(详细版)

前言:

作用:
首先

useMemo

它使用来做缓存用的,只有当一个依赖项改变的时候才会发生变化,否则拿缓存的值,就不用在每次渲染的时候再做计算

场景:
既然是用作缓存来用,那场景就可能有:

  1. 比如说当你登陆之后,你的个人信息一般是不会变的,当你退出登陆,重新输入另外一个人的账号密码之后,这个时候个人信息可能就变了,那这样我就可以把账号密码`两个作为依赖项,当他们变了,那就更新个人信息,否则拿缓存的值,从而达到优化的目的
  2. 也许有时候,你可能需要从A页面跳转到B页面,并携带一些参数,那就会从路由下手,类似于:http://localhost:3000/home/:id/:name或者http://localhost:3000//home?id=123&name=zhangsan,然后B页面基于这些参数做一些查询操作,那路由不变,其实这些查询出来的数据应该是不变的(当然其中包含增删改操作除外),那就可以把这些路由参数当作依赖项,只有依赖项变了,该页面的数据才会变

使用

直接上代码:

App根组件:

在这里插入图片描述

Home组件:

在这里插入图片描述

效果图:

在这里插入图片描述

效果上:

根据上面的效果图,可看出有价值可能就是控制台打印出的顺序,发现

useMemo

是在

useEffect

前面的,如果你之前对

useEffct

有了解的话,可能知道它可看成

class

组件里面的

componentDidMount

componentDidUpdate

componentWillUnmount

这三个函数的组合。 而

useMemo

则可以看作是

componentWillUpdate

函数,顺序大致如下:
在这里插入图片描述

代码上:

useMemo(参数1,参数2)
  • 参数1:是一个创建依赖项函数,该函数的返回值就是你想要缓存的数据,但形式上感觉挺想useEffect的,所以我才拿出来做对比,当然实际上两者却存在着很多差异
  • 参数2:这个是个数组,存放着被依赖的项,意思就是说只有当这个数组里面的变量发生了变化,才会调用参数1的函数,这里同样跟useEffect很像,都是依赖项变了,才会调用前面的参数1的函数

最后再来看下动态图:请添加图片描述

最后发现:
我们

useMemo

是加了

count

依赖项的,而

useEffect

是没有加的,所以说只有点了

count+1

,才会分别执行

useMemo

useEffect

的参数1的函数,而当点了

value+1

useMemo

不会调用参数1,而

useEffect

会调用参数1

至此

useMemo

基本用法就是这样,以及和

useEffect

的对比,当然还有与useMemo相对应的还有个useCallback,它是缓存函数的,感兴趣可以了解一下


本文转载自: https://blog.csdn.net/m0_46694056/article/details/122189832
版权归原作者 Poker_旭 所有, 如有侵权,请联系我们删除。

“react简单入门--常用hook中useMemo的使用(详细版)”的评论:

还没有评论