React.Memo和useMemo的区别?

文章目录

前言

hello world欢迎来到前端的新世界


😜当前文章系列专栏:react.js

🐱‍👓博主在前端领域还有很多知识和技术需要掌握,正在不断努力填补技术短板。(如果出现错误,感谢大家指出)🌹

💖感谢大家支持!您的观看就是作者创作的动力
React.memo和useMemo是React中两个不同的特性,用于优化组件性能,但它们的作用和使用方式有所不同。

React.memo

  • React.memo是一个高阶函数,用于优化函数组件的渲染性能。
  • React.memo接收一个组件作为参数,并返回一个经过优化的新组件。
  • React.memo会对组件的输入属性进行浅层比较。只有当组件的输入属 性发生变化时,才会重新渲染该组件。如果组件的输入属性没有变化,那么React.memo会直接返回上次渲染的结果,从而避免不必要的渲染。
  • 例如,可以使用React.memo来包装一个组件,以确保它只在输入属性发生变化时才重新渲染。

useMemo

  • useMemo是一个自定义的React Hook,用于在函数组件中进行内存缓存和性能优化。
  • useMemo接收一个工厂函数和一个依赖数组作为参数,并返回一个缓存的值。
  • useMemo会在首次渲染或依赖项发生变化时执行工厂函数,并将结果缓存起来。当下次渲染时,如果依赖项没有发生变化,useMemo会直接返回上次缓存的值,避免重复计算。
  • 例如,可以使用useMemo来缓存一个昂贵的计算结果,以避免在每次渲染时都重新计算。

总结

  • React.memo用于优化组件的渲染性能,避免不必要的重复渲染。
  • useMemo用于在函数组件中进行内存缓存和性能优化,避免重复计算。

后言

创作不易,要是本文章对广大读者有那么一点点帮助 不妨三连支持一下,您的鼓励就是博主创作的动力

相关推荐
万少4 分钟前
第五款 HarmonyOS 上架作品 奇趣故事匣 来了
前端·harmonyos·客户端
OpenGL9 分钟前
Android targetSdkVersion升级至35(Android15)相关问题
前端
rzl0225 分钟前
java web5(黑马)
java·开发语言·前端
Amy.Wang26 分钟前
前端如何实现电子签名
前端·javascript·html5
今天又在摸鱼29 分钟前
Vue3-组件化-Vue核心思想之一
前端·javascript·vue.js
蓝婷儿31 分钟前
每天一个前端小知识 Day 21 - 浏览器兼容性与 Polyfill 策略
前端
百锦再33 分钟前
Vue中对象赋值问题:对象引用被保留,仅部分属性被覆盖
前端·javascript·vue.js·vue·web·reactive·ref
jingling55538 分钟前
面试版-前端开发核心知识
开发语言·前端·javascript·vue.js·面试·前端框架
拾光拾趣录42 分钟前
CSS 深入解析:提升网页样式技巧与常见问题解决方案
前端·css
莫空000043 分钟前
深入理解JavaScript属性描述符:从数据属性到存取器属性
前端·面试