您现在的位置是:亿华云 > 人工智能
一篇带给你 React.memo 如何使用?
亿华云2025-10-08 21:00:05【人工智能】3人已围观
简介大家好,我是前端西瓜哥。最近做的新功能有性能问题,所以我想尝试优化一下 React 组件的性能。下面我们来好好学习一下 React.memo 的用法。组件状态更新和重渲染当某个组件里的状态发生改变时,
大家好,篇带我是何使前端西瓜哥。
最近做的篇带新功能有性能问题,所以我想尝试优化一下 React 组件的何使性能。下面我们来好好学习一下 React.memo 的篇带用法。
组件状态更新和重渲染
当某个组件里的何使状态发生改变时,React 会调用该组件的篇带 render 方法,生成新的何使 React 元素树,和原来的篇带虚拟 DOM 对比,找出不同的何使地方然后给真实的 DOM 打补丁。
如果有子组件,篇带它也会被重新渲染。何使
这里有一个问题:有些子组件其实并没有发生状态改变,篇带也被重新渲染,何使占用了 CPU 资源。篇带
虽然这个操作是不必要的,但 React 并不能知道传给子组件的 props 是否发生了改变。
但 React 提供了 React.memo() 方法,希望你能通过它来告知 React 该组件是否跳过重渲染。源码库
React.memo
React.memo 是一个 高阶组件。
所谓高阶组件,其实指的就是一个接收组件并返回一个组件的函数。起名参考了高阶函数,但确实花里胡哨了一些。
React.memo 的作用是 缓存 组件,它会对传入的组件加上缓存功能生成一个新组件,然后返回这个新组件。
在传给组件的 props 的属性和值没有发生改变的情况下,它会使用最近一次缓存的结果,而不会进行重新的渲染,实现跳过组件渲染的效果。
下面是一个示例:
const Comp = ({ color }) => { return ( <div> <div>{ color}</div> </div> );};// 生成一个可以缓存结果的组件const MemoriedComp = React.memo(Comp);当我们使用 MemoriedBox 时,如果传入的 props.color 保持不变的话,MemoriedBox 组件就不会发生重渲染。
这里有一个演示例子:
https://codesandbox.io/s/react-memo-huan-cun-ce-shi-k96vd4。服务器托管保证 props 的有效对比
比较算法React.memo 判断是否使用缓存,默认使用的是浅比较,也就是只比较第一层的 key。
shallowEqual 主要是通过 Object.is 来对比。源码实现地址如下:
https://github.com/facebook/react/blob/HEAD/packages/shared/shallowEqual.js。
有时候我们希望自定义比较方法,这时候我们可以使用 React.memo 方法的第二个参数,传入我们自定义的比较方法。
const isEqual(prevProps, nextProps) { // 自定义对比方法}const MemoriedComp = React.memo(Comp, isEqual);自定义比较方法会拿到两参数:旧的和新的 props 对象,然后根据该方法的返回值来决定是否使用缓存。如果为真值,使用缓存,否则重新渲染并把新的渲染结果缓存下来。
假设我们有一个 prop 是数组,但因为声明语句写在组件里,所以每次渲染时都会生成一个指向新的内存空间的另一个数组,服务器租用导致新旧 prop 指向不同的内存对象,但它们的数组元素却是依次相等。
[1, 2] === [1, 2] // false有时候我们想将它们认为 “相同”,能够触发 React.memo 方法的缓存。
用浅比较会返回 false,进行重渲染,不符合我们的预期。这时候就可以使用自己实现的 深比较(深度递归比较),可以考虑使用比较有名的 lodash.isEqual。
缓存函数
对于数组和普通对象,我们可以用深比较来判断 “相等”。但对于函数组件中每次都会被重新构建的函数,显然是行不通的。函数没有结构。
对于函数,我们可以使用 useCallback。
const Comp = () => { const onClick = React.useCallback(() => { if (isOk) sumbit(); }, [isOk]) return ( <div> <Button onClick={ onClick}></Button> </div> )}useCallback 接受一个函数和一个依赖项数组,当依赖项数组里的元素没有改变时,会使用最后一次缓存的函数,否则会使用传入的新函数。
除了用 useCallback 缓存函数,我们还可以用 useMemo 来缓存其他的对象值。
避免负优化
只渲染一次,之后都不会更新的组件,不要使用 React.memo。props 每次都会改变的组件,不要使用 React.memo,使用 React.memo 只会带来不必要的新旧 props 比较和无意义的缓存。组件如果很简单,不建议使用 React.memo,并不能带来多大提升,而使用 React.memo 本身就有心智负担。如果你无法很好地量化性能,不建议使用 React.memo。结尾
React.memo 可以帮助我们跳过一些不必要的组件渲染。但要维护好对象类型 prop 的不改变,确实对我们造成不少的心智负担。
React.memo 并不是一定会有正收益的,因为缓存也是有成本的。
很赞哦!(68)
相关文章
- 4、club娱乐
- 域名不仅仅是一个简单的网站。对于有长远眼光的公司来说,在运营网站之前确定一个优秀的域名对有长远眼光的公司来说是非常重要的。这对今后的市场营销、产品营销和企业品牌建设都具有十分重要的意义。优秀的域名是企业在市场竞争中获得持久优势的利器。
- 主流搜索引擎显示的相关搜索项越多,越能积极反映该域名的市场价值。同时,被评估域名的搜索引擎显示结果不佳可能是由于以下两个原因:
- .net 适用于从事Internet相关的网络服务的机构或公司
- 2016年1月1日:注册价格将降至每年7欧元。
- 在众多公司中,如果我们必须选择一家可信的公司,那当然是信得过的。
- 第六:这个圈子里的域名确实是赚钱的一些大玩家,至于小米农,有多少赚钱?几乎没有,也就是说,轿子里只有一个人,而且大多数人都抬着轿子。
- 只要我们做的是从目前的市场情况选择域名,从简单易记,从个性特征上,我们就可以找到一个好域名进行注册。域名注册进行域名记录和解析以及绑定网站后,客户可以通过URL登录您的网站。
- 为什么喜欢国外注册域名?国外注册域名注意什么?
- 互联网中的地址是数字的IP地址,域名解析的作用主要就是为了便于记忆。
热门文章
站长推荐
3、商标域名一经注册,就可以作为域名裁决过程中的主要信息之一。这可以大大增加公司被抢注的相关域名胜诉的机会。
2、根据用户基础选择访问提供程序。由于互联问题的存在,接入商的选择也非常重要,如果用户群主要在联通,尽量选择联通接入较好的接入商,如果用户群主要在电信,那么选择电信接入较好的接入商。如果用户组位于国家/地区,则选择更好的访问提供程序进行交互。
要如何了解反向解析和域名解析?新手该怎么去操作?
2. 不要花大价钱买域名,新手鉴别能力不足,容易投资失误。
打开https://www.aizhan.com/输入自己想要查询的域名然后按回车键,如果做过网站都会有数据显示出来
4、club娱乐
当投资者经过第二阶段的认真学习之后又充满了信心,认为自己可以在市场上叱咤风云地大干一场了。但没想到“看花容易绣花难”,由于对理论知识不会灵活运用.从而失去灵活应变的本能,就经常会出现小赢大亏的局面,结果往往仍以失败告终。这使投资者很是困惑和痛苦,不知该如何办,甚至开始怀疑这个市场是不是不适合自己。在这种情况下,有的人选择了放弃,但有的意志坚定者则决定做最后的尝试。
以上的就是为大家介绍的关于域名的详解域名注册:域名注册0