iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >react的context和props详解
  • 644
分享到

react的context和props详解

2024-04-02 19:04:59 644人浏览 薄情痞子
摘要

目录一、context1. 使用场景2. 使用步骤3. 总结二、props深入1. children 属性2. props 校验3. props校验使用步骤4. props校验约束规

一、context

1. 使用场景

设想一个场景,假如我们要给子孙组件传值,应该怎么办呢?

如果使用props一层一层往下 传递的话,特别的繁琐!

更好的办法:使用context来帮助我们跨组件传递数据

2. 使用步骤

  • 调用 React.createContext() 创建 Provider(提供数据) 和 Consumer(消费数据) 两个组件

const { Provider, Consumer } = React.createContext()
  • 使用 Provider 组件作为父节点。

<Provider>
  <div className="App">
    <Child1 />
  </div>
</Provider>
  • 设置 value 属性,表示要传递的数据。

<Provider value="pink">
  • 调用 Consumer 组件接收数据。

<Consumer>
  {data => <span>data参数表示接收到的数据 -- {data}</span>}
</Consumer>

3. 总结

  • 如果两个组件是多层嵌套可以使用Context实现组件通讯
  • Context提供了两个组件:Provider Consumer
  • Provider组件:用来提供数据
  • Consumer组件:用来消费数据

二、props深入

1. children 属性

children 属性:表示组件标签的子节点。当组件标签有子节点时,props 就会有该属性

children 属性与普通的props一样,值可以是任意值(文本、标签、组件、甚至是函数)

代码如下(示例):


function Hello(props) {
  return (
    <div>
      组件的子节点:{props.children}
    </div>
  )
}
<Hello>我是子节点</Hello>

2. props 校验

对于组件来说,props 是外部数据的容器,无法保证组件使用者传入什么格式的数据

如果传入的数据格式不对,可能会导致组件内部报错

关键问题:除了语法报错信息之外没有额外的错误提示

代码如下(示例):


// 创建的组件
function App(props) {
  const arr = props.colors
  const list = arr.map((item, index) => <li key={index}>{item}</li>)
  return (
    <ul>{list}</ul>
  )
}
// 使用组件时
<App colors={19} />

props 校验:允许在创建组件的时候,就指定 props 的类型、格式等

作用:捕获使用组件时因为props导致的错误,给出明确的错误提示,增加组件的健壮性

在这里插入图片描述

3. props校验使用步骤

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

import PropTypes from 'prop-types'
function App(props) {
  return (
    <h1>Hi, {props.colors}</h1>
  )
}
App.propTypes = {
  // 约定colors属性为array类型
  // 如果类型不对,则报出明确错误,便于分析错误原因
  colors: PropTypes.array
}

4. props校验约束规则

常见类型: numberstringarrayboolfuncobject

React元素类型:element

必填项:isRequired

特定结构的对象:shape({ })


// 常见类型
optionalFunc: PropTypes.func,
// 必选
requiredFunc: PropTypes.func.isRequired,
// 特定结构的对象
optionalObjectWithShape: PropTypes.shape({
  color: PropTypes.string,
  fontSize: PropTypes.number
})

5. props默认值

场景:分页组件 → 每页显示条数

作用:给 props 设置默认值,在未传入 props 时生效


function App(props) {
  return (
    <div>
      此处展示props的默认值:{props.pageSize}
    </div>
  )
}
// 设置默认值
App.defaultProps = {
  pageSize: 10
}
// 不传入pageSize属性
<App />

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容!

--结束END--

本文标题: react的context和props详解

本文链接: https://www.lsjlt.com/news/156905.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作