二. React的使用 PropTypes 进行类型检查

注意:从React v15.5开始,React.PropTypes助手函数已被启用,建议使用prop-types库来定义contextTypes

PropTypes 输出了一系列的验证器,可以用来确保接收到的参数是有效的。例如,我们可以使用PropTypes.string 语句。当给 prop 传递了一个不正确的值时,JavaScript控制台将会显示一条警告。

使用目的

若你再之后的项目维护中或开发中,修改了prop的属性类型,则可以在控制台中发现并改正,从而可以避免造成不必要的bug。

默认的 prop 值

可以通过赋值特定的defaultProps属性为props定义默认值,如果父组件没有为this.props.name传值,defaultProps会给其一个默认值。propTypes的类型检测是在defaultProps解析之后发生的,因此也会对默认属性defaultProps进行类型检测。

import PropTypes from 'prop-types';

class Greeting extends React.Component {
  render() {
    return (
      

Hello, {this.props.name}

); } } Greeting.propTypes = { name: PropTypes.string };

在本例中, 我们使用了 PropTypes.string。当传入的 prop 值类型不正确时,JavaScript 控制台将会显示警告。出于性能的原因,propTypes仅在开发模式中检测。

defaultProps 用于确保 this.props.name 在父组件没有指定其值时,有一个默认值。从而组件不会因为没有值而变成空白或者报错。propTypes 类型检查发生在 defaultProps 赋值后,所以类型检查也适用于 defaultProps。

PropTypes

以下提供了使用不同验证器的例子:

import PropTypes from 'prop-types';

MyComponent.propTypes = {
  optionalArray: PropTypes.array,
  optionalBool: PropTypes.bool,
  optionalFunc: PropTypes.func,
  optionalNumber: PropTypes.number,
  optionalObject: PropTypes.object,
  optionalString: PropTypes.string,
  optionalSymbol: PropTypes.symbol,
  optionalNode: PropTypes.node,
  optionalElement: PropTypes.element,
  optionalMessage: PropTypes.instanceOf(Message),
  optionalEnum: PropTypes.oneOf(['News', 'Photos']),
  optionalUnion: PropTypes.oneOfType([
    PropTypes.string,
    PropTypes.number,
    PropTypes.instanceOf(Message)
  ]),
  optionalArrayOf: PropTypes.arrayOf(PropTypes.number),
  optionalObjectOf: PropTypes.objectOf(PropTypes.number),
  optionalObjectWithShape: PropTypes.shape({
    color: PropTypes.string,
    fontSize: PropTypes.number
  }),
  requiredFunc: PropTypes.func.isRequired,
  requiredAny: PropTypes.any.isRequired
};

你可能感兴趣的:(二. React的使用 PropTypes 进行类型检查)