学习 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} />
搭配 useMemo
和 useCallback
才能把 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 没变就跳过更新 |
使用场景 | 重组件、纯展示组件、性能敏感区域 |
搭配技巧 | useMemo 、useCallback |
使用风险 | props 变化频繁或为新对象时,memo 失效 |
🧪 面试官问我 React.memo,我怎么答?
React.memo 是一个用于优化函数组件性能的高阶组件,底层通过浅比较 props 判断组件是否需要更新。适合用于渲染成本高、props 稳定的组件,能减少不必要的重复渲染。在大型项目中常搭配 useMemo / useCallback 一起使用,提升性能。
完美收官!
最后一句话:React.memo,是你写"懒惰但高效组件"的第一步
如果你也正在 React 路上摸爬滚打,想进阶、想优化、想提升,记住:
有时候,写出"不做事"的组件,才是高阶开发者的智慧 😎
如果你觉得这篇文章对你有帮助,点个赞 + 收藏支持一下吧!
评论区也欢迎一起交流你踩过的 memo 坑,或者你用 memo 做过的优化!