react hook: useCallback

useCallback的主要使用场景在于优化性能,并确保当传递回调函数给子组件时,子组件不会因为父组件的重渲染而重新创建函数。

使用场景

1.当你需要将回调函数传递给子组件时,使用useCallback可以确保子组件在重新渲染时不会不必要地重新创建函数。

2.如果某个函数的创建和调用频率较高,使用useCallback可以优化组件的性能。

3.作为依赖项传递给useEffect,并且这些回调函数在渲染期间没有发生变化时,使用useCallback可以确保useEffect不会因为回调函数的重新创建而触发不必要的副作用。
如果你正在编写一个 自定义 Hook,建议将它返回的任何函数包裹在 useCallback 中:这确保了 Hook 的使用者在需要时能够优化自己的代码。

javascript 复制代码
function useRouter() {
  const { dispatch } = useContext(RouterStateContext);

  const navigate = useCallback((url) => {
    dispatch({ type: 'navigate', url });
  }, [dispatch]);

  const goBack = useCallback(() => {
    dispatch({ type: 'back' });
  }, [dispatch]);

  return {
    navigate,
    goBack,
  };
}

const handleSubmit = useCallback(() => {}) 首次渲染时会创建一次,并在组件更新时,如果依赖项没有发生变化,则会返回之前创建的函数引用,而不是重新创建一个新的函数。
不能在模版循环中使用 useCallback ,但是这不被允许

为单个项目提取一个组件,然后在组件内部使用 useCallback

或者可以将组件包裹在memo 中 如果 组件props 没有更改,组件 将跳过重新渲染

相关推荐
用户5757303346244 分钟前
🐱 从“猫厂”倒闭到“鸭子”横行:一篇让你笑出腹肌的 JS 面向对象指南
javascript
Moment5 分钟前
腾讯终于对个人开放了,5 分钟在 QQ 里养一只「真能干活」的 AI 😍😍😍
前端·后端·github
码路飞14 分钟前
GPT-5.4 Computer Use 实战:3 步让 AI 操控浏览器帮你干活 🖥️
java·javascript
比尔盖茨的大脑15 分钟前
AI Agent 架构设计:从 ReAct 到 Multi-Agent 系统
前端·人工智能·全栈
天才熊猫君17 分钟前
使用 Vite Mode 实现客户端与管理端的物理隔离
前端
HelloReader19 分钟前
React Hook 到底是干嘛的?
前端
用户605723748730820 分钟前
OpenSpec 实战:从需求到代码的完整工作流
前端·后端·程序员
进击的尘埃21 分钟前
Service Worker 离线缓存这事,没你想的那么简单
javascript
进击的尘埃23 分钟前
HTTP/3 的多路复用和 QUIC 到底能让页面快多少?聊聊连接迁移和 0-RTT
javascript