一、为什么使用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,

五、class定义中使用方法

class Greeting extends React.Component {
render() {
return (
<h1>Hello, {this.props.name}</h1>
);
}
} // Specifies the default values for props:
Greeting.defaultProps = {
name: 'Stranger'
}; // Renders "Hello, Stranger":
ReactDOM.render(
<Greeting />,
document.getElementById('example')
);

六、ES7中使用方法示例

class Greeting extends React.Component {
//如果没有传递该属性时的默认值
static defaultProps = {
name: 'stranger'
}
//如果传递该属性,该属性值必须为字符串
static propTypes={
name:PropTypes.string
}
render() {
return (
<div>Hello, {this.props.name}</div>
)
}
}

七、使用isRequired设置属性为必须传递的值

 static propTypes={
name:PropTypes.string.isRequired
}

八、arrOf和objectOf多重嵌套类型检测

  // An array of a certain type
optionalArrayOf: PropTypes.arrayOf(PropTypes.number), // An object with property values of a certain type
optionalObjectOf: PropTypes.objectOf(PropTypes.number),
//示例
static propTypes = {
todoList:PropTypes.arrayOf(PropTypes.shape({
id:PropTypes.string.isRequired,
text:PropTypes.string
}))
}

九、shape检测不同对象的不同属性的不同数据类型

  // An object taking on a particular shape
optionalObjectWithShape: PropTypes.shape({
optionalProperty: PropTypes.string,
requiredProperty: PropTypes.number.isRequired
}),
//示例
static propTypes = {
object:PropTypes.shape({
name:PropTypes.string,
age:PropTypes.number
})
}
 
 

13人点赞

 
react

 
 
"小礼物走一走,来简书关注我"

作者:500薪水程序员
链接:https://www.jianshu.com/p/a73fb26c88b5
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

最新文章

  1. Linux上的free命令详解、swap机制
  2. Windows综合应用
  3. SQL日期格式,转自will哥
  4. C#编程普通型计算器 经验与感悟
  5. windows 下 node 多版本管理工具 - gnvm
  6. oracle 触发器number判断空值,:NEW赋值,for each row,sql变量引号,to_date,to_char
  7. new Random().nextInt
  8. FPGrowth算法原理
  9. Cocos2D-X2.2.3学习笔记8(处理精灵单击、双击和三连击事件)
  10. 关于AIX VG中 LV 的状态问题,LV STATE
  11. 设计完美的策略模式,消除If-else
  12. ubuntu only enable left click
  13. FineUIMvc新特性速递(大间距模式,隐藏菜单垂直滚动条)
  14. (Android系统目录结构)目录预览
  15. CentOS7配置httpd虚拟主机
  16. iOS 崩溃分析
  17. django403错误(转)
  18. JVM调优——之CMS GC日志分析
  19. Macbook pro睡眠状态恢复后没声音的解决办法
  20. 比较分析 Spring AOP 和 AspectJ 之间的差别

热门文章

  1. EF分页查询
  2. 用launchscreen.storyboard适配启动图方法(二)
  3. 挑战10个最难的Java面试题(附答案)【上】【华为云技术分享】
  4. 联万物,+智能,为行业,华为云升级OceanConnect IoT全栈云服务
  5. 全面认识 RUST -- 掌控未来的雷电
  6. Python ——selenium报错 &#39;chromedriver.exe&#39; executable needs to be in PATH
  7. dubbo 订阅 RPC 服务
  8. POJ1458 Subsquence
  9. linux 通过管道更方便的查询输入记录
  10. Docker系列-(1) 原理与基本操作