useMemo和useCallback到底有什么区别

不知道大家在工作中有没有用到 useMemouseCallback 这两个钩子,笔者总是忘记这两者的区别,现在写一篇记录彻底搞懂这两个 Hook 的区别。

useMemouseCallback 它们都用于优化性能,它们主要是用途有所不同。

useMemo

useMemo 用于记忆一个计算值。当你有一个性能消耗比较大的计算操作,并且你不希望在每次组件渲染时都重新计算它时,你可以使用 useMemo。这个钩子只有在其依赖项发生变化时才会重新计算记忆值。

jsx 复制代码
const memoizedValue = useMemo(() => computeExpensiveValue(a, b), [a, b]);

在这个例子中,computeExpensiveValue 只有在 ab 改变时才会重新执行。如果不用useMemo 钩子,就会每次在组件渲染时计算。造成性能浪费。

useCallback

useCallback 用于记忆一个函数实例。主要应用于将函数作为 props 传递给子组件的场景,特别是当这些子组件使用了 React.memoshouldComponentUpdate 时。如果你不使用 useCallback,那么每次父组件渲染时都会创建一个新的函数实例,即使这个函数的实际代码并没有改变。此时,就会导致子组件也会重新渲染。

jsx 复制代码
const memoizedCallback = useCallback(() => {
  doSomething(a, b);
}, [a, b]);

在这个例子中,只有当 ab 改变时,函数 doSomething 的实例才会改变。

主要区别

  • 用途useMemo 用于缓存计算结果,useCallback 用于缓存函数实例。
  • 返回值useMemo 返回的是函数执行的结果,useCallback 返回的是函数本身。
  • 使用场景
    • 使用 useMemo 当你需要避免在每次渲染时都进行昂贵的计算。
    • 使用 useCallback 当你需要将相同的回调函数传递给优化过的子组件,以避免不必要的渲染。

在实际应用中,应该避免过度使用这些钩子,因为不恰当的使用可能会导致性能问题,而不是优化。例如,过度使用 useMemouseCallback 可能会导致内存占用增加,因为记忆的值和函数实例需要被存储在内存中。

相关推荐
0思必得02 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5163 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino3 小时前
图片、文件的预览
前端·javascript
layman05285 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔5 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李5 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN5 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒5 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库5 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
电商API_180079052475 小时前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫