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 没有更改,组件 将跳过重新渲染

相关推荐
今天不要写bug6 分钟前
基于elementUI实现一个可编辑的表格(简洁版)
前端·javascript·elementui
上优9 分钟前
Vue3纯前端同源跨窗口通信移动AGV小车
前端·vue.js·状态模式
h_k1008610 分钟前
Chrome 插件开发入门技术文章大纲
前端·chrome
一只小阿乐10 分钟前
vue-router 的实现原理
前端·javascript·vue.js·路由·vue-router
Zz_waiting.11 分钟前
案例开发 - 日程管理 - 第七期
开发语言·前端·javascript·vue.js·html·路由
writeone11 分钟前
9-10关于JS初学产生的问题
开发语言·javascript·ecmascript
一只小风华~14 分钟前
Vue:事件处理机制详解
前端·javascript·vue.js·typescript·前端框架
dy17174 小时前
element-plus表格默认展开有子的数据
前端·javascript·vue.js
2501_915918418 小时前
Web 前端可视化开发工具对比 低代码平台、可视化搭建工具、前端可视化编辑器与在线可视化开发环境的实战分析
前端·低代码·ios·小程序·uni-app·编辑器·iphone
程序员的世界你不懂8 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库