React PropTypes验证arrayOf所需元素无法正常工作

时间:2016-09-13 12:37:58

标签: reactjs react-proptypes

空数组[]传递以下PropTypes定义,即使我们声明字符串元素是必需的。

{
    a: React.PropTypes.arrayOf(
        React.PropTypes.string.isRequired
    ).isRequired
}

相反,空对象{}不传递以下propTypes定义:

{
    a: React.PropTypes.shape({
        x: PropTypes.string.isRequired
    }).isRequired
}

数组验证似乎无法正常工作。有什么想法吗?

1 个答案:

答案 0 :(得分:3)

您可以使用自定义验证器。我不相信你可以在没有项目的情况下强制执行arrayOf中的string.isRequired ..根据arrayOf的自定义验证器如何工作,它似乎调用每个键的回调。因此,如果值没有键,则不会调用验证器。

(注意,这不是经过测试的)

a: function(props, propName, componentName) {
  var errorCount = 0
  var prop = props[propName]
  // ensure it is an array
  if (typeof prop !== 'array') {
    errorCount++
  }
  // ensure array has items
  else if (prop.length == 0) {
    errorCount++
  }
  // ensure all items are strings
  else {
    for (var i = 0; i < prop.length; i++) {
      if (typeof prop[i] !== 'string') errorCount++
    }
  }
  // throw error
  if (errorCount > 0) {
    return new Error(
      'Invalid prop `' + propName + '` supplied to' +
      ' `' + componentName + '`. Validation failed.'
    );
  }