boxmoe_header_banner_img

Hello! 欢迎来到盒子萌!

加载中

文章导读

03组件


avatar
Jack 2023年 3月 3日 203

React组件进阶

组件通讯介绍

组件是独立且封闭的单元,默认情况下,只能使用组件自己的数据。在组件化过程中,我们将一个完整的功能拆分成多个组件,以更好的完成整个应用的功能。而在这个过程中,多个组件之间不可避免的要共享某些数据。为了实现这些功能,就需要打破组件的独立封闭性,让其与外界沟通,这个过程就是组件通讯

组件的props(★★★)

基本使用

    • 组件时封闭的,要接受外部数据应该通过props来实现
    • props的作用:接收传递给组件的数据
    • 传递数据:给组件标签添加属性
    • img
    • 接收数据:函数组件通过 参数 props接收数据,类组件通过 this.props接收数据
      • 函数组件获取
      img
      • 类组件获取
      img

    特点

    • 可以给组件传递任意类型的数据
    • props是只读属性,不能对值进行修改
    • 注意:使用类组件时,如果写了构造函数,应该将props传递给super(),否则,无法在构造函数中获取到props,其他的地方是可以拿到的
    img

    组件通讯的三种方式(★★★)

    父组件传递数据给子组件

    • 父组件提供要传递的state数据
    • 给子组件标签添加属性,值为state中的数据
    • 子组件中通过props接收父组件中传递的数据
    img

    子组件传递数据给父组件

    • 利用回调函数,父组件提供回调,子组件调用,将要传递的数据作为回调函数的参数
    • 父组件提供一个回调函数,用来接收数据
    • 将该函数作为属性的值,传递给子组件
    img
    • 子组件通过props调用回调函数
    img

    兄弟组件传递

    • 将共享状态(数据)提升到最近的公共父组件中,由公共父组件管理这个状态
    • 这个称为状态提升
    • 公共父组件职责:1. 提供共享状态 2.提供操作共享状态的方法
    • 要通讯的子组件只需要通过props接收状态或操作状态的方法

    Context(★★★)

    如果出现层级比较多的情况下(例如:爷爷传递数据给孙子),我们会使用Context来进行传递 作用: 跨组件传递数据

    使用步骤

    • 调用 React.createContext() 创建 Provider(提供数据) 和 Consumer(消费数据) 两个组件
    img
    • 使用Provider 组件作为父节点
    img
    • 设置value属性,表示要传递的数据
    img
    • 哪一层想要接收数据,就用Consumer进行包裹,在里面回调函数中的参数就是传递过来的值
    img

    小结

    • 如果两个组件相隔层级比较多,可以使用Context实现组件通讯
    • Context提供了两个组件:Provider 和 Consumer
    • Provider组件: 用来提供数据
    • Consumer组件: 用来消费数据

    props进阶

    children属性

    • children属性: 表示组件标签的子节点,当组件标签有子节点时,props就会有该属性
    • children属性与普通的props一样,值可以使任意值(文本、react元素、组件、甚至是函数)
    img

    props校验(★★★)

    • 对于组件来说,props是外来的,无法保证组件使用者传入什么格式的数据,简单来说就是组件调用者可能不知道组件封装着需要什么样的数据
    • 如果传入的数据不对,可能会导致报错
    • 关键问题:组件的使用者不知道需要传递什么样的数据
    • props校验:允许在创建组件的时候,指定props的类型、格式等
    img
    • 作用:捕获使用组件时因为props导致的错误,给出明确的错误提示,增加组件的健壮性
    img

    使用步骤

    • 安装包 prop-types (yarn add prop-types | npm i props-types)
    • 导入prop-types 包
    • 使用组件名.propTypes={} 来给组件的props添加校验规则
    • 校验规则通过PropTypes对象来指定
    img

    常见的约束规则

    • 创建的类型: array、bool、func、number、object、string
    • React元素类型:element
    • 必填项:isRequired
    • 特定结构的对象: shape({})
    • 更多的约束规则(opens new window)
    img

    props的默认值

    • 场景:分页组件 -> 每页显示条数


评论(0)

查看评论列表

暂无评论


发表评论

表情 颜文字
插入代码