空数组[]传递以下PropTypes定义,即使我们声明字符串元素是必需的。
{
a: React.PropTypes.arrayOf(
React.PropTypes.string.isRequired
).isRequired
}
相反,空对象{}不传递以下propTypes定义:
{
a: React.PropTypes.shape({
x: PropTypes.string.isRequired
}).isRequired
}
数组验证似乎无法正常工作。有什么想法吗?
答案 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.'
);
}