Browse Source

Update typechecking-with-proptypes.md

Revert the code style and change the paragraph. And thanks for @bvaughn's advise.
main
kinyaying 7 years ago
committed by GitHub
parent
commit
b66d5442f9
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 14
      content/docs/typechecking-with-proptypes.md

14
content/docs/typechecking-with-proptypes.md

@ -148,10 +148,6 @@ MyComponent.propTypes = {
You can define default values for your `props` by assigning to the special `defaultProps` property: You can define default values for your `props` by assigning to the special `defaultProps` property:
```javascript ```javascript
const defaultProps = {
name: 'Stranger'
};
class Greeting extends React.Component { class Greeting extends React.Component {
render() { render() {
return ( return (
@ -161,7 +157,9 @@ class Greeting extends React.Component {
} }
// Specifies the default values for props: // Specifies the default values for props:
Greeting.defaultProps = defaultProps; Greeting.defaultProps = {
name: 'Stranger'
};
// Renders "Hello, Stranger": // Renders "Hello, Stranger":
ReactDOM.render( ReactDOM.render(
@ -170,10 +168,10 @@ ReactDOM.render(
); );
``` ```
You can also put the defaultProps as static props inside React class. If you are using a Babel transform like [transform-class-properties](https://babeljs.io/docs/plugins/transform-class-properties/) , you can also declare `defaultProps` as static property within a React component class. This syntax has not yet been finalized though and will require a compilation step to work within a browser. For more information, see the [class fields proposal](https://github.com/tc39/proposal-class-fields).
```javascript ```javascript
class Greeting extends Component { class Greeting extends React.Component {
static defaultProps = { static defaultProps = {
name: 'stranger' name: 'stranger'
@ -187,6 +185,4 @@ class Greeting extends Component {
} }
``` ```
It is considerably more convenient. But non-functional properties are not currently supported for ES2015 classes, you should install extra plugin to support this syntax. If you want to only use strictly ES2015, the former syntax is the better choice.
The `defaultProps` will be used to ensure that `this.props.name` will have a value if it was not specified by the parent component. The `propTypes` typechecking happens after `defaultProps` are resolved, so typechecking will also apply to the `defaultProps`. The `defaultProps` will be used to ensure that `this.props.name` will have a value if it was not specified by the parent component. The `propTypes` typechecking happens after `defaultProps` are resolved, so typechecking will also apply to the `defaultProps`.

Loading…
Cancel
Save