usemeno和usecallback区别及使用场景

1. useMemo

  • 用途 : useMemo 用于缓存计算结果。它接受一个函数和依赖项数组,只有当依赖项发生变化时,才会重新计算该函数的返回值。否则,它会返回缓存的值。

  • 返回值 : useMemo 返回的是函数执行后的结果

  • 使用场景:

    • 当一个计算量大的函数在每次渲染时都被调用,而计算结果在依赖项没有改变的情况下是相同的时,可以使用 useMemo 来避免重复计算,从而提高性能。

    • 例如,在渲染列表时,计算过滤后的列表或排序后的数据可以使用 useMemo 来缓存结果。

复制代码
javascript复制代码const filteredData = useMemo(() => {
  return data.filter(item => item.active);
}, [data]);

2. useCallback

  • 用途 : useCallback 用于缓存函数引用。它接受一个函数和依赖项数组,只有当依赖项发生变化时,才会返回一个新的函数引用。否则,它会返回缓存的函数引用。

  • 返回值 : useCallback 返回的是函数本身。

  • 使用场景:

    • 当一个函数被传递给子组件,或者作为依赖项传递给 useEffectuseMemouseContext 等 Hook 时,避免因函数重新创建导致子组件不必要的重新渲染,可以使用 useCallback

    • 例如,在子组件依赖于父组件传递的回调函数时,使用 useCallback 可以确保子组件只在必要时重新渲染。

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

总结

  • useMemo 是为了优化计算,避免不必要的重复计算。

  • useCallback 是为了优化函数,避免不必要的函数重新创建,减少子组件的重新渲染

相关推荐
AAA阿giao5 小时前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
摘星编程18 小时前
React Native鸿蒙版:Image图片占位符
react native·react.js·harmonyos
飞羽殇情1 天前
基于React Native鸿蒙跨平台开发构建完整电商预售系统数据模型,完成参与预售、支付尾款、商品信息展示等
react native·react.js·华为·harmonyos
摘星编程1 天前
React Native + OpenHarmony:ImageSVG图片渲染
javascript·react native·react.js
摘星编程1 天前
OpenHarmony + RN:Text文本书写模式
javascript·react native·react.js
xixixin_1 天前
【React】中 Body 类限定法:优雅覆盖挂载到 body 的组件样式
前端·javascript·react.js
摘星编程1 天前
用React Native开发OpenHarmony应用:Image网络图片加载
javascript·react native·react.js
摘星编程1 天前
OpenHarmony环境下React Native:ImageBase64图片显示
javascript·react native·react.js
摘星编程1 天前
React Native鸿蒙:Image本地图片显示
javascript·react native·react.js
2501_921930831 天前
基础入门 React Native 鸿蒙跨平台开发:Video 全屏播放与画中画 鸿蒙实战
react native·react.js·harmonyos