React 深度学习:memo

path:packages/react/src/memo.js

源码

import {REACT_MEMO_TYPE} from 'shared/ReactSymbols';

import isValidElementType from 'shared/isValidElementType';
import warningWithoutStack from 'shared/warningWithoutStack';

export default function memo<Props>(
  type: React$ElementType,
  compare?: (oldProps: Props, newProps: Props) => boolean,
) {
  if (__DEV__) {
    // do something
  }
  return {
    $$typeof: REACT_MEMO_TYPE,
    type,
    compare: compare === undefined ? null : compare,
  };
}

复制代码

memo 方法接受两个参数:

  • type:必选参数,它是一个 React 组件。这里没有限定传入的 class 组件还是函数式组件。
  • compare:可选参数,它是一个返回布尔值的比较函数。用于比较前后两个 props 是否相等。

memo 方法返回一个 $$typeofREACT_MEMO_TYPE 的对象

memo 组件如何被解析

  1. memo 组件如何被解析
  2. memo 如何进行 props 比较

转载于:https://juejin.im/post/5d10e7136fb9a07eed350b53

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值