--- title: "New in React v0.4: Prop Validation and Default Values" author: [zpao] --- Many of the questions we got following the public launch of React revolved around `props`, specifically that people wanted to do validation and to make sure their components had sensible defaults. ## Validation {#validation} Oftentimes you want to validate your `props` before you use them. Perhaps you want to ensure they are a specific type. Or maybe you want to restrict your prop to specific values. Or maybe you want to make a specific prop required. This was always possible — you could have written validations in your `render` or `componentWillReceiveProps` functions, but that gets clunky fast. React v0.4 will provide a nice easy way for you to use built-in validators, or to even write your own. ```js React.createClass({ propTypes: { // An optional string prop named "description". description: React.PropTypes.string, // A required enum prop named "category". category: React.PropTypes.oneOf(['News','Photos']).isRequired, // A prop named "dialog" that requires an instance of Dialog. dialog: React.PropTypes.instanceOf(Dialog).isRequired }, ... }); ``` ## Default Values {#default-values} One common pattern we've seen with our React code is to do something like this: ```js React.createClass({ render: function() { var value = this.props.value || 'default value'; return