React Hook 解析(一):useCallback 与 useMemo

📘 本系列将系统解析 React 中的常用 Hooks,帮助你深入理解背后的原理与使用场景。本篇聚焦于两个性能优化利器:useCallbackuseMemo


✨ 为什么需要它们?

React 在组件每次重新渲染时,都会重新执行函数体:

  • 每个函数、对象、数组都重新创建新引用

  • 会导致子组件重复渲染

  • 会造成重复的复杂计算

我们可以用 useCallbackuseMemo 来优化这些性能问题。


🔁 useCallback:缓存函数引用

✅ 基本用法

tsx 复制代码
const memoizedFn = useCallback(() => {
  // 逻辑...
}, [依赖项]);

每当依赖项不变时,返回的函数引用保持不变。

✅ 使用场景

  • 将事件函数传递给 React.memo 包裹的子组件,避免不必要的重新渲染

  • 减少事件绑定的频率(例如鼠标滚动、点击)

✅ 示例

tsx 复制代码
const handleClick = useCallback(() => {
  console.log('clicked');
}, []);

对比:

tsx 复制代码
const handleClick = () => {
  console.log('clicked');
};

不使用 useCallback,每次组件渲染都会新建一个 handleClick 函数,导致引用变化。


🧠 useMemo:缓存计算值

✅ 基本用法

tsx 复制代码
const memoizedValue = useMemo(() => {
  return expensiveComputation(input);
}, [input]);

只有当依赖 input 变化时才会重新执行 expensiveComputation

✅ 使用场景

  • 缓存复杂计算结果

  • 避免创建新的对象、数组,防止触发子组件更新

  • 数据筛选、排序等逻辑

✅ 示例

tsx 复制代码
const filteredList = useMemo(() => {
  return list.filter(item => item.includes(keyword));
}, [list, keyword]);

🔄 与 React.memo 联动优化子组件渲染

tsx 复制代码
const Child = React.memo(({ onClick }: { onClick: () => void }) => {
  console.log('子组件渲染');
  return <button onClick={onClick}>Click</button>;
});
tsx 复制代码
const handleClick = useCallback(() => {
  console.log('clicked');
}, []);
<Child onClick={handleClick} />

如果不使用 useCallback,每次父组件重渲染都会导致 onClick 引用变化,从而让 Child 也重新渲染。


📌 useCallback vs useMemo 对比

特性 useCallback useMemo
返回值 函数 任何计算后的值
用途 缓存函数引用,避免重复定义 缓存计算结果,避免重复运算
常见使用场景 向子组件传递函数 缓存数组、对象、复杂计算
本质 useMemo(() => fn, deps) useMemo(() => value, deps)

🧷 注意事项

  • 只有在真正的性能瓶颈或子组件频繁渲染时再使用

  • 滥用可能引入复杂性

  • 依赖数组必须写全,防止缓存失效或 bug


✅ 小结

Hook 优化对象 典型场景
useCallback 函数 事件绑定、传递函数 props
useMemo 复杂计算、缓存数组/对象

📚 下一篇我们将解析:useEffect 的执行时机与副作用陷阱。

相关推荐
sorryhc1 天前
如何设计一个架构良好的前端请求库?
前端·javascript·架构
lvchaoq1 天前
react 修复403页面无法在首页跳转问题
前端·javascript·react.js
郝开1 天前
6. React useState基础使用:useState修改状态的规则;useState修改对象状态的规则
前端·javascript·react.js
Codigger官方1 天前
Linux 基金会牵头成立 React 基金会:前端开源生态迎来里程碑式变革
linux·前端·react.js
90后的晨仔1 天前
🌟 Vue3 + Element Plus 表格开发实战:从数据映射到 UI 优化的五大技巧
前端
ObjectX前端实验室1 天前
【图形编辑器架构】🧠 Figma 风格智能选择工具实现原理【猜测】
前端·react.js
天桥下的卖艺者1 天前
R语言基于shiny开发随机森林预测模型交互式 Web 应用程序(应用程序)
前端·随机森林·r语言·shiny
技术钱1 天前
vue3 两份json数据对比不同的页面给于颜色标识
前端·vue.js·json
路很长OoO1 天前
Flutter 插件开发实战:桥接原生 SDK
前端·flutter·harmonyos
技术钱1 天前
react+andDesign+vite+ts从零搭建后台管理系统(三)-Layout布局
javascript·react.js·ecmascript