Browse Source

Added new documentation showing use of a custom validator for arrayOf or objectOf, specifically how the method signature for such a validator differs from the customProp validator method signature. Made minor edits to error message for customProp example to match error messages found in src.

main
Matthew Herbst 9 years ago
parent
commit
5693f30959
  1. 19
      docs/05-reusable-components.md

19
docs/05-reusable-components.md

@ -70,9 +70,26 @@ React.createClass({
// won't work inside `oneOfType`. // won't work inside `oneOfType`.
customProp: function(props, propName, componentName) { customProp: function(props, propName, componentName) {
if (!/matchme/.test(props[propName])) { if (!/matchme/.test(props[propName])) {
return new Error('Validation failed!'); return new Error(
'Invalid prop `' + propName + '` supplied to' +
' `' + componentName + '`. Validation failed.'
);
} }
},
// You can also supply a custom validator to `arrayOf` and `objectOf`.
// It should return an Error object if the validation fails. The validator
// will be called for each key in the array or object. The first two
// arguments of the validator are the array or object itself, and the
// current item's key.
customArrayProp: React.PropTypes.arrayOf(function(propValue, key, componentName, location, propFullName) {
if (!/matchme/.test(propValue[key])) {
return new Error(
'Invalid prop `' + propFullName + '` supplied to' +
' `' + componentName + '`. Validation failed.'
);
} }
})
}, },
/* ... */ /* ... */
}); });

Loading…
Cancel
Save