白嫖 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 做过的优化!

相关推荐
xw536 分钟前
uni-app项目跑APP报useStore报错
前端·uni-app
!win !40 分钟前
uni-app项目跑APP报useStore报错
前端·uni-app
拾光拾趣录42 分钟前
Flexbox 布局:从“垂直居中都搞不定”到写出响应式万能布局
前端·css
渣渣盟1 小时前
JavaScript核心概念全解析
开发语言·javascript·es6
huxihua20061 小时前
各种前端框架界面
前端
拾光拾趣录1 小时前
GET/POST 的区别:从“为什么登录请求不能用 GET”说起
前端·网络协议
Carlos_sam2 小时前
OpenLayers:ol-wind之渲染风场图全解析
前端·javascript
拾光拾趣录2 小时前
闭包:从“变量怎么还没死”到写出真正健壮的模块
前端·javascript
拾光拾趣录2 小时前
for..in 和 Object.keys 的区别:从“遍历对象属性的坑”说起
前端·javascript
OpenTiny社区2 小时前
把 SearchBox 塞进项目,搜索转化率怒涨 400%?
前端·vue.js·github