加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

React丨PropTypes & defaultProps

发布时间:2020-12-15 16:17:39 所属栏目:百科 来源:网络整理
导读:? 简单示例 import PropTypes from ‘prop-types‘ ;class Greeting extends React.Component { render() { return ( h1Hello,{ this .props.name}/h1 ); }}Greeting.propTypes = { name: PropTypes.string}; ? ? PropTypes 解析: import PropTypes from ‘

?

简单示例

import PropTypes from ‘prop-types‘;

class Greeting extends React.Component {
  render() {
    return (
      <h1>Hello,{this.props.name}</h1>
    );
  }
}

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

?

?

PropTypes 解析:

import PropTypes from ‘prop-types‘;

MyComponent.propTypes = {
  // 可以定义一个属性是特定的JS类型(Array,Boolean,Function,Number,Object,String,Symbol)。默认情况下,这些都是可选的。
  optionalArray: PropTypes.array,optionalBool: PropTypes.bool,optionalFunc: PropTypes.func,optionalNumber: PropTypes.number,optionalObject: PropTypes.object,optionalString: PropTypes.string,optionalSymbol: PropTypes.symbol,// 指定类型为:任何可以被渲染的元素,包括数字,字符串,react 元素,数组,fragment。
  optionalNode: PropTypes.node,// 一个react 元素
  optionalElement: PropTypes.element,// 可以类型为某个类的实例,这里使用JS的instanceOf操作符实现
  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
  }),//加上isReqired限制,可以指定某个属性必须提供,如果没有出现警告。
  requiredFunc: PropTypes.func.isRequired,
  requiredAny: PropTypes.any.isRequired,// 也可以指定一个自定义的验证器。如果验证不通过,它应该返回Error对象,而不是`console.warn `或抛出错误。`oneOfType`中不起作用。
  customProp: function(props,propName,componentName) {
    if (!/matchme/.test(props[propName])) {
      return new Error(
        ‘Invalid prop `‘ + propName + ‘` supplied to‘ +
        ‘ `‘ + componentName + ‘`. Validation failed.‘
      );
    }
  },// 也可以提供一个自定义的验证器 arrayOf和objectOf。如果验证失败,它应该返回一个Error对象。
  // 验证器用来验证数组或对象的每个值。验证器的前两个参数是数组或对象本身,还有对应的key。
  customArrayProp: PropTypes.arrayOf(function(propValue,key,componentName,location,propFullName) {
    if (!/matchme/.test(propValue[key])) {
      return new Error(
        ‘Invalid prop `‘ + propFullName + ‘` supplied to‘ +
        ‘ `‘ + componentName + ‘`. Validation failed.‘
      );
    }
  })
};

?

?

import PropTypes from ‘prop-types‘;

class MyComponent extends React.Component {
  render() {
    // This must be exactly one element or it will warn.
    const children = this.props.children;
    return (
      <div>
        {children}
      </div>
    );
  }
}

MyComponent.propTypes = {
  children: PropTypes.element.isRequired
};

?

Default Prop Values

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‘)
);

?

class Greeting extends React.Component {
  static defaultProps = {
    name: ‘stranger‘
  }

  render() {
    return (
      <div>Hello,{this.props.name}</div>
    )
  }
}

?

?

参考:

https://github.com/wangjianuo/blog/issues/3

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读