useMemo 和 React.memo区别

useMemoReact.memo 区别总结(一句话版)

  • useMemo :缓存 计算结果,避免重复执行耗时计算。

  • React.memo :缓存 组件渲染结果,避免组件因 props 不变而重新渲染。


✅ 一、useMemo ------ 缓存"值"

用途

用来缓存 计算成本高依赖不变 时不需要重复计算的值。

示例:

复制代码
const expensiveValue = useMemo(() => {
  return computeHeavy(a, b); // 这段代码很耗性能
}, [a, b]);

只要 ab 不变,computeHeavy 就不会再次执行。

适用场景

  • 大量计算,比如循环 10k 条数据

  • 生成复杂对象,避免子组件 props 变化

  • 缓存格式化数据、防止重复运算


✅ 二、React.memo ------ 缓存"组件"

用途

让一个组件在 props 未变化时跳过渲染

示例:

复制代码
const Child = React.memo(function Child({ value }) {
  console.log("child render");
  return <div>{value}</div>;
});

如果 value 不变,Child 不会重新渲染。

适用场景

  • 减少子组件重复渲染

  • 列表中的小项

  • 组件 props 很少变化时


⚠️ 但有坑 ⚠️

默认情况下:

复制代码
<Child data={{ a: 1 }} />

因为 { a: 1 } 每次渲染都创建新的对象,所以 props 永远变化,memo 就失效了。

解决:

复制代码
const data = useMemo(() => ({ a: 1 }), []);
<Child data={data} />;

✅ 三、两者配合使用(最佳实践)

常见优化模式:

复制代码
const data = useMemo(() => ({ a: count }), [count]);

const Child = React.memo(({ data }) => {
  return <div>{data.a}</div>;
});
  • useMemo 用来保证 data 对象稳定

  • React.memo 用来让 Child 组件不重复渲染


📌 最终对比表

特性 useMemo React.memo
缓存的内容 计算结果(值) 组件渲染结果
触发条件 依赖变化重新计算 props 变化重新渲染
用途 避免重复计算 避免重复渲染子组件
是否用于组件本身 ✔️
是否用于数据/对象 ✔️

🎯 什么时候用哪个?

  • 有复杂计算 → 用 useMemo

  • 子组件不要重复渲染 → 用 React.memo

  • 子组件 props 传对象导致 memo 失效 → useMemo + React.memo 组合


相关推荐
怕浪猫几秒前
React从入门到出门 第五章 React Router 配置与原理初探
前端·javascript·react.js
jinmo_C++几秒前
从零开始学前端 · HTML 基础篇(一):认识 HTML 与页面结构
前端·html·状态模式
哈__5 分钟前
React Native 鸿蒙跨平台开发:LayoutAnimation 实现鸿蒙端表单元素的动态添加动画
react native·react.js·harmonyos
鹏多多7 分钟前
前端2025年终总结:借着AI做大做强再创辉煌
前端·javascript
哈__10 分钟前
React Native 鸿蒙跨平台开发:Vibration 实现鸿蒙端设备的震动反馈
javascript·react native·react.js
小Tomkk15 分钟前
⭐️ StarRocks Web 使用介绍与实战指南
前端·ffmpeg
不一样的少年_19 分钟前
产品催: 1 天优化 Vue 官网 SEO?我用这个插件半天搞定(不重构 Nuxt)
前端·javascript·vue.js
-dcr21 分钟前
50.智能体
前端·javascript·人工智能·ai·easyui
行者9630 分钟前
Flutter跨平台开发适配OpenHarmony:进度条组件的深度实践
开发语言·前端·flutter·harmonyos·鸿蒙
云和数据.ChenGuang31 分钟前
Uvicorn 是 **Python 生态中用于运行异步 Web 应用的 ASGI 服务器**
服务器·前端·人工智能·python·机器学习