React高阶组件——React.momo

父子组件的渲染规律

因为子组件是父组件的一部分,默认父组件发生变化时候子组件也会重新渲染。

react.memo的提出

但是当子组件状态变化触发重新渲染时,父组件不会重新触发,因为为避免不必要的渲染,会缩在最小范围内。就不会让父组件也发生重新渲染。 但是如果子组件非常复杂,还要在每次父组件重新渲染的时候跟着被渲染,就会产生 无意义的损耗。 为此,用react.memo来缓存子组件,当子组件的状态没变化时候就不用重新渲染。当子组件真的变化了,再重新渲染,重新缓存。

使用方法:

从react中解构出来memo const {memo}=react 用memo包裹子组件

js 复制代码
    const Child=memo(()=>{
      return <>
      <h1>{count}</h1>
      <button onClick={()=>setcount(count+1)}>+</button>
      <button onClick={()=>setcount(count-1)}>-</button>
      </>
    })

意思就是memo括号中的整个作为一个参数,memo就返回一个已经缓存化/记忆化的这样一个组件child。 父组件里面不变,直接用<child/>

重新缓存的情况:

  1. props组件嵌套属性改变
  2. state组件自身状态改变
  3. useContext跨组件通信数据改变

重新缓存失败的情况:

  • 复杂数据类型(引用类型) :数组 (arr)、函数 (fn)、对象等是通过引用地址 传递的。每次父组件重新渲染时,即使内容未变,这些值也会被重新创建 ,导致内存地址变化,React.memo 的浅比较会认为 props 发生了变化,从而触发子组件重新渲染。

  • 简单数据类型(原始类型) :如 stringnumberbooleannullundefinedsymbol 等,直接比较值是否相同,不会因内存地址问题引发重新渲染。

  • 解决方法:

    1. 使用 useMemo 缓存数组/对象
      避免父组件每次渲染时重新创建引用:
    ini 复制代码
    const memoizedArr = useMemo(() => [1, 2, 3], []);
    <ChildComponent arr={memoizedArr} />
  1. 使用 useCallback 缓存函数

    确保函数引用不变:

    ini 复制代码
    const memoizedFn = useCallback(() => {}, []);
    <ChildComponent fn={memoizedFn} />
  2. 自定义 areEqual 比较函数

    手动控制 React.memo 的 props 比较逻辑:

    csharp 复制代码
    const areEqual = (prevProps, nextProps) => {
      return prevProps.arr.join() === nextProps.arr.join();
    };
    export default React.memo(ChildComponent, areEqual);
相关推荐
2601_949809593 分钟前
flutter_for_openharmony家庭相册app实战+相册详情实现
javascript·flutter·ajax
qq_177767378 分钟前
React Native鸿蒙跨平台通过Animated.Value.interpolate实现滚动距离到动画属性的映射
javascript·react native·react.js·harmonyos
2601_9498333917 分钟前
flutter_for_openharmony口腔护理app实战+饮食记录实现
android·javascript·flutter
2601_9494800626 分钟前
【无标题】
开发语言·前端·javascript
css趣多多30 分钟前
Vue过滤器
前端·javascript·vue.js
●VON1 小时前
React Native for OpenHarmony:项目目录结构与跨平台构建流程详解
javascript·学习·react native·react.js·架构·跨平台·von
爱吃大芒果1 小时前
Flutter for OpenHarmony 实战:mango_shop 路由系统的配置与页面跳转逻辑
开发语言·javascript·flutter
qq_177767371 小时前
React Native鸿蒙跨平台实现消息列表用于存储所有消息数据,筛选状态用于控制消息筛选结果
javascript·react native·react.js·ecmascript·harmonyos
沐雪架构师2 小时前
LangChain 1.0 Agent开发实战指南
开发语言·javascript·langchain
2501_940007892 小时前
Flutter for OpenHarmony三国杀攻略App实战 - 战绩记录功能实现
开发语言·javascript·flutter