白嫖 React 性能优化?是的,用 React.memo!

学习 React 的路上,我总有一种"写着写着就卡顿"的感觉。

后来我才知道,是我把组件喂得太勤快了,明明 props 没变,它还天天重新渲染。

于是我学会了一个"能懒就懒"的技能:React.memo


前言:

学习 React 的过程中,我发现组件之间的"沟通"和"重渲染"像极了人际关系:

  • 有些组件明明没变,但却天天"参与社交",性能开销像请客吃饭一样频繁。
  • 我开始意识到:我需要一个"宅属性组件",不必要就别出门,别浪费资源!

于是,我遇见了 React.memo ------ 一个能让组件"装死"的优化黑科技。


React.memo 是什么?

一句话解释:

React.memo 是一个高阶组件(HOC),用于缓存函数组件的渲染结果,只有当 props 真正发生变化时才重新渲染。

官方定义(翻译版):

js 复制代码
const MemoizedComponent = React.memo(Component)

当你用 React.memo 包裹一个组件,它就会对传入的 props 进行 浅比较

  • 如果 props 没变,组件就直接复用上次的渲染结果。
  • 如果 props 变了,才会重新渲染。

说白了,它帮你判断:"这个组件到底有没有必要更新?"


举个例子更香

来看个小例子,假设你有一个 todo 项组件:

js 复制代码
const TodoItem = ({ todo }) => {
  console.log('渲染了:', todo.text);
  return <li>{todo.text}</li>;
};

你把它放在一个列表里:

js 复制代码
function TodoList({ todos }) {
  return (
    <ul>
      {todos.map((todo) => (
        <TodoItem key={todo.id} todo={todo} />
      ))}
    </ul>
  );
}

每当你新增一个 todo,所有 TodoItem 都会重新渲染,哪怕它们根本没变。

🧙‍♂️ 用 React.memo 优化一下:

js 复制代码
const TodoItem = React.memo(({ todo }) => {
  console.log('渲染了:', todo.text);
  return <li>{todo.text}</li>;
});

✨只会渲染新增的那一项,其余的组件都被 memo 缓存住了!


memo 做了什么?到底"懒"在哪?

React.memo 做的就是浅比较(shallow compare)

js 复制代码
(prevProps, nextProps) => {
  return prevProps === nextProps; // 或每一项都 ===
}

所以你传的 props 要注意:

js 复制代码
<TodoItem todo={{ text: '喝水' }} />

上面这种每次都是新对象(新引用),即使值一样,memo 也认不出来。

正确写法:

js 复制代码
const stableTodo = useMemo(() => ({ text: '喝水' }), []);
<TodoItem todo={stableTodo} />

搭配 useMemouseCallback 才能把 memo 的威力完全释放!


🧯 memo 的误区(踩坑警告⚠️)

情况 是否推荐使用 memo
组件很复杂、渲染成本高 ✅ 推荐
props 基本不变 ✅ 推荐
组件很简单、props 频繁变 ❌ 没必要
每次 props 都是新对象 ❌ memo 白搭

❗不要给所有组件都加 memo!

memo 本身也有性能成本,不变才优化,变了反而浪费对比时间


自定义对比函数,让 memo 更聪明

js 复制代码
const MyComponent = React.memo((props) => {
  return <div>{props.name}</div>;
}, (prevProps, nextProps) => {
  // 返回 true 表示一样,不更新
  return prevProps.name === nextProps.name;
});

你可以自定义判断逻辑,比如对嵌套对象、函数类型做更复杂的判断。


总结一下:我学到什么了?

知识点 理解方式
React.memo 是干嘛的 缓存组件,防止无用渲染
它做了什么 对 props 做浅比较,props 没变就跳过更新
使用场景 重组件、纯展示组件、性能敏感区域
搭配技巧 useMemouseCallback
使用风险 props 变化频繁或为新对象时,memo 失效

🧪 面试官问我 React.memo,我怎么答?

React.memo 是一个用于优化函数组件性能的高阶组件,底层通过浅比较 props 判断组件是否需要更新。适合用于渲染成本高、props 稳定的组件,能减少不必要的重复渲染。在大型项目中常搭配 useMemo / useCallback 一起使用,提升性能。

完美收官!


最后一句话:React.memo,是你写"懒惰但高效组件"的第一步

如果你也正在 React 路上摸爬滚打,想进阶、想优化、想提升,记住:

有时候,写出"不做事"的组件,才是高阶开发者的智慧 😎


如果你觉得这篇文章对你有帮助,点个赞 + 收藏支持一下吧!

评论区也欢迎一起交流你踩过的 memo 坑,或者你用 memo 做过的优化!

相关推荐
你也向往长安城吗23 分钟前
基于 navmesh 的路径搜索技术剖析 (游戏、三维方向必看!!!)
javascript·游戏·游戏开发
JustHappy42 分钟前
「Versakit攻略」🔥Pnpm+Monorepo+Changesets搭建通用组件库项目和发包流程
前端·javascript·vue.js
紫金龙腾1 小时前
EDGE 、chrome、浏览器显示“由你的组织管理”
前端·chrome·edge
用户66197734585751 小时前
Vue3笔记
前端·vue.js
long3161 小时前
适配器模式 java demo
java·javascript·后端·程序人生·设计模式·适配器模式
2401_837088503 小时前
ref 简单讲解
前端·javascript·vue.js
折果3 小时前
如何在vue项目中封装自己的全局message组件?一步教会你!
前端·面试
不死鸟.亚历山大.狼崽子3 小时前
Syntax Error: Error: PostCSS received undefined instead of CSS string
前端·css·postcss
汪子熙3 小时前
Vite 极速时代的构建范式
前端·javascript
叶常落3 小时前
[react] js容易混淆的两种导出方式2025-08-22
javascript