React中Props的详细使用和props的校验
props中的children属性
组件标签只用有子节点的时候,props就会有该属性;
children的属性跟props一样的,值可以是任意值;(文本,React元素,组件,函数)
组件: <ClassCom> 传递的数据 </ClassCom>
这样的组件标签中就会有子节点
props中的children的简单使用
<!-- 主页面 -->
import React from 'react';
import ReactDOM from 'react-dom';
import ClassCom from "./components/ClassCom"
ReactDOM.render(<ClassCom>传递的数据</ClassCom>,document.getElementById('root'))
子组件
import React from "react";
// 函数组件
// const ClassCom = (props) => {
// return (
// <div>
// <h2>组件</h2>
// { props.children }
// </div>
// )
// }
// 类组件
class ClassCom extends React.Component{
render() {
return (
<div>
<p>-------我是子组件--------</p>
{this.props.children}
</div>
)
}
}
export default ClassCom

props中children的属性是标签
<!-- 主页面 -->
import React from 'react'; //这个是react这个包,我们是需要的
import ReactDOM from 'react-dom'; //这个是react的虚拟dom
import ClassCom from "./components/ClassCom"
ReactDOM.render(<ClassCom>
<p>我是一个p标签</p>
</ClassCom>, document.getElementById('root'))
<!-- 子组件 -->
import React from "react";
// 类组件
class ClassCom extends React.Component{
render() {
return (
<div>
<p>-------我是子组件--------</p>
{this.props.children}
</div>
)
}
}
export default ClassCom

props的校验
为什么会有props的校验。因为props是外来的。
我们无法保证使用者传递过来的参数是什么格式的。
如果我们这个props是数组,而使用者传递的是数字。
这个时候会出现意想不到的后果。
所以我们需要对props进行校验,如props的类型,格式。
校验步骤
1.需要安装一个包 yarn add prop-types 或者 npm i prop-types
2.导包 import PropTypes from 'prop-types'
3. 组件名.PropTypes = { 属性:PropTypes.类型 }
PropTypes的类型有
PropTypes.array 数组
PropTypes.bool 布尔
PropTypes.func 函数
PropTypes.number
PropTypes.object
PropTypes.string
props校验的简单使用
//组件
import React from "react";
// 导包
import PropTypes from 'prop-types'
// 类组件
class ClassCom extends React.Component{
render() {
return (
<div>
{
this.props.arr.map(item => <li key={item.id }> { item.name}</li>)
}
数字: {this.props.num }
</div>
)
}
}
ClassCom.propTypes = {
// 希望传递过来的arr是数组
arr: PropTypes.array,
num:PropTypes.number
}
export default ClassCom
当传递的数据不符合条件的时候

import React from 'react';
import ReactDOM from 'react-dom';
import ClassCom from "./components/ClassCom"
const list = [{name:'李大为',id:1},{name:'夏洁',id:2}]
ReactDOM.render(<ClassCom arr={list} num={100}></ClassCom>, document.getElementById('root'))
Props的约束规则
// num属性是必填写的
num: PropTypes.number.isRequired,
// 特定结果的对象
myObj: PropTypes.shape({
name: PropTypes.string,
age: PropTypes.number,
sex:PropTypes.bool
})
// 表示是一个React元素
tag:PropTypes.element
Props的默认值的设置
// ClassCom是组件名称
ClassCom.defaultProps = {
pageSize:10
}
使用的时候 页数: { this.props.pageSize}
Props限制的简单使用
import React from 'react';
import ReactDOM from 'react-dom';
import ClassCom from "./components/ClassCom"
const list = [{ name: '李大为', id: 1 }, { name: '夏洁', id: 2 }]
const obj = {
name: 123, //这个类型不正确
sex: '男',
age:18
}
ReactDOM.render(<ClassCom arr={list} num={100} myObj={ obj}></ClassCom>, document.getElementById('root'))
import React from "react";
// 导包
import PropTypes from 'prop-types'
// 类组件
class ClassCom extends React.Component{
render() {
return (
<div>
{
this.props.arr.map(item => <li key={item.id }> { item.name}</li>)
}
数字: {this.props.num}
页数 { this.props.pageSize}
</div>
)
}
}
ClassCom.propTypes = {
// 希望传递过来的arr是数组
arr: PropTypes.array,
// num属性是必填写的
num: PropTypes.number.isRequired,
// 特定结果的对象
myObj: PropTypes.shape({
name: PropTypes.string,
age: PropTypes.number,
sex:PropTypes.bool
}),
// 表示是一个React元素
tag: PropTypes.element
}
<!-- 这是默认值 -->
ClassCom.defaultProps = {
pageSize:10
}
export default ClassCom

React中Props的详细使用和props的校验的更多相关文章
- react中constructor和super()以及super(props)的区别。
react中这两个API出镜率超级高,但是一直不太懂这到底是干嘛的,有什么用:今天整理一下,方便自己查看同时方便大家. 1.constructor( )-----super( )的基本含义 const ...
- react中的jsx详细理解
这是官网上的一个简单的例子 const name = 'Josh Perez'; const element = <h1>Hello, {name}</h1>; ReactDO ...
- React中的Context——从父组件传递数据
简介:在React中,数据可以以流的形式自上而下的传递,每当你使用一个组件的时候,你可以看到组件的props属性会自上而下的传递.但是,在某些情况下,我们不想通过父组件的props属性一级一级的往下传 ...
- React中render Props模式
React组件复用 React组件复用的方式有两种: 1.render Props模式 2.高阶组件HOC 上面说的这两种方式并不是新的APi. 而是利用Raect自身的编码特点,演化而来的固定编码写 ...
- React中props.children和React.Children的区别
在React中,当涉及组件嵌套,在父组件中使用props.children把所有子组件显示出来.如下: function ParentComponent(props){ return ( <di ...
- React中props
今天让我们开启新的篇章好吧,来搞一搞React,以下所有操作都是我个人的一些理解,如果有错吴还请指出,想要看更全的可以去React官网可能一下子好吧 昨天按摩没到位,导致今天身体不太行,撸码千万别苦了 ...
- React中Props 和 State用法
React中Props 和 State用法 1.本质 一句话概括,props 是组件对外的接口,state 是组件对内的接口.组件内可以引用其他组件,组件之间的引用形成了一个树状结构(组件树),如果下 ...
- react中直接调用子组件的方法(非props方式)
我们都知道在 react中,若要在父组件调用子组件的方法,通常我们会采用在父组件定义一个方法,作为props转给子组件,然后执行该方法,可以获取到子组件传回的参数以得到我们的目的. 显而易见,这个执行 ...
- react 中state与props
react 中state与props 1.state与props props是只读属性,只有在组件被实例化的时候可以赋值,之后的任何时候都无法改变该值.如果试图修改该值时,控制台会报错 only re ...
- React中props与state
以下内容均为个人理解. 1.state: 在react中,state可以看成管理页面状态的集合(实则一个对象而已),库里面的成员均为页面渲染变量,整个页面为一个状态机,当state发生变化时,页面会重 ...
随机推荐
- 字节跳动基于ClickHouse优化实践之Upsert
更多技术交流.求职机会.试用福利,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 相信大家都对大名鼎鼎的ClickHouse有一定的了解,它强大的数据分析性能让人印象深刻.但在字节大量生 ...
- Solon2 开发之IoC,六、提取 Bean 的函数进行定制开发
为什么需要提取Bean的函数?绝不是闲得淡疼.比如:控制器的@Mapping:再比如:Xxl-Job的@XxlJob.这些都是要提取Bean的函数并定制加工的. 1.比如提取 @XxlJob 注解的函 ...
- Axure 元件--基本元件
图片:导入图看,根据图片实际大小显示,双击方框,再导入,根据控件的大小来显示图片 热区:1:增加锚点,制作点击事件:2:放在页面下方,控制滚动位置,比如其它控件在交互事件中找到它的坐标. 动态面版:交 ...
- Jenkins + SVN/Git + Maven + Docker + 阿里云镜像 + Kubernetes(K8S)
Jenkins 2361.2 + Maven Integration + SVN/GIT + Docker + 阿里云镜像 + Kubernetes(K8S) 本文用于学习,了解原理,和实际应用,有所 ...
- Codeforces Round #656 (Div. 3)部分题解
Codeforces Round #656 (Div. 3)题解 A.Three Pairwise Maximums 解题思路: 依照题意和样例,三个整数x,y,z必须有两个相同且都比第三个数大. 如 ...
- 【每日一题】35. [CQOI2009]中位数图 (前缀和,贡献值计算)
补题链接:Here 算法涉及:前缀和,贡献值计算 经典中位数计数问题,记得以前百度之星也出过类似的题,这道题有一个限定范围是要奇数区间的 我们很容易想到,奇数下标到偶数下标或者偶数下标到奇数下标的长度 ...
- Kafka的Rebalance机制可能造成的影响及解决方案
一.kafka的rebalance机制在Kafka中,当有新消费者加入或者订阅的Topic数发生变化时,会触发Rebalance(再均衡:在同一个消费者组当中,分区的所有权从一个消费者转移到另外一个消 ...
- 二、Mycat安装
系列导航 一.Mycat实战---为什么要用mycat 二.Mycat安装 三.mycat实验数据 四.mycat垂直分库 五.mycat水平分库 六.mycat全局自增 七.mycat-ER分片 万 ...
- 3D编程模式:开篇
大家好~现在开始新的系列文章:3D编程模式系列 本系列会介绍从我的实际开发经验中抽象提炼出来的编程模式,大家可直接应用它们到3D引擎开发.编辑器开发等领域中 相关资料: 课程录像回放 代码和课程ppt ...
- vue如何实现v-model