一、为什么使用prop-types
在多人开发时,当被人使用自己定义的组件时,有可能出现类型传错的情况,而在自己的组件上加上prop-types,他可以对父组件传来的props进行检查,加入父组件中想传递的是字符串类型‘3’,而传递了一个数字类型3,如果没有类型检查系统不会给与提示,但是有了类型检查以后,再控制台会给你一个类型传递错误的提示。这样在工作中可以快速找到错误。
二、学习文档
https://www.npmjs.com/package/prop-types npm官网 https://reactjs.org/docs/typechecking-with-proptypes.html react官方
三、安装与引入
//安装 npm install prop-types --save //引入 import PropTypes from 'prop-types';
四、它可以检测的类型
optionalArray: PropTypes.array, optionalBool: PropTypes.bool, optionalFunc: PropTypes.func, optionalNumber: PropTypes.number, optionalObject: PropTypes.object, optionalString: PropTypes.string, optionalSymbol: PropTypes.symbol,
五、demo
import React, { Component } from 'react'
import PropTypes from 'prop-types';
//子组件
class Children extends Component {
//如果没有传递该属性时的默认值
static defaultProps = { //写class里面就用static 如果是外面就是下面的写法
name: 'default'
}
static propTypes = {
//如果传递该属性,该属性值必须为字符串
name: PropTypes.string
}
render() {
return (
<div>
{this.props.name}
</div>
)
}
}
//如果没有传递该属性时的默认值
// Children.defaultProps = {
// name: 'default'
// }
// Children.propTypes = {
// //如果传递该属性,该属性值必须为字符串
// name: PropTypes.string.isRequired
// }
//父组件
export default class Home extends Component {
render() {
return (
<div>
<Children/>
Home
</div>
)
}
}
七、使用isRequired设置属性为必须传递的值
static propTypes={
name:PropTypes.string.isRequired
}
八、arrOf和objectOf多重嵌套类型检测
optionalArrayOf: PropTypes.arrayOf(PropTypes.number),
optionalObjectOf: PropTypes.objectOf(PropTypes.number),
//示例
static propTypes = {
todoList:PropTypes.arrayOf(PropTypes.shape({
id:PropTypes.string.isRequired,
text:PropTypes.string
}))
}
九、shape检测不同对象的不同属性的不同数据类型
optionalObjectWithShape: PropTypes.shape({
optionalProperty: PropTypes.string,
requiredProperty: PropTypes.number.isRequired
}),
//示例
static propTypes = {
object:PropTypes.shape({
name:PropTypes.string,
age:PropTypes.number
})
}
浙公网安备 33010602011771号