You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
63 lines
1.6 KiB
63 lines
1.6 KiB
11 years ago
|
---
|
||
11 years ago
|
id: props-in-getInitialState-as-anti-pattern
|
||
|
title: Props in getInitialState Is an Anti-Pattern
|
||
11 years ago
|
layout: tips
|
||
11 years ago
|
permalink: props-in-getInitialState-as-anti-pattern.html
|
||
11 years ago
|
prev: componentWillReceiveProps-not-triggered-after-mounting.html
|
||
|
next: dom-event-listeners.html
|
||
11 years ago
|
---
|
||
|
|
||
11 years ago
|
> Note:
|
||
|
>
|
||
|
> This isn't really a React-specific tip, as such anti-patterns often occur in code in general; in this case, React simply points them out more clearly.
|
||
|
|
||
|
Using props, passed down from parent, to generate state in `getInitialState` often leads to duplication of "source of truth", i.e. where the real data is. Whenever possible, compute values on-the-fly to ensure that they don't get out of sync later on and cause maintenance trouble.
|
||
|
|
||
|
Bad example:
|
||
11 years ago
|
|
||
|
```js
|
||
|
/** @jsx React.DOM */
|
||
|
|
||
|
var MessageBox = React.createClass({
|
||
|
getInitialState: function() {
|
||
|
return {nameWithQualifier: "Mr. " + this.props.name};
|
||
|
},
|
||
|
render: function() {
|
||
|
return <div>{this.state.nameWithQualifier}</div>;
|
||
|
}
|
||
|
});
|
||
|
|
||
|
React.renderComponent(<MessageBox name="Zuck"/>, mountNode);
|
||
|
```
|
||
|
|
||
11 years ago
|
Better:
|
||
11 years ago
|
|
||
|
```js
|
||
|
/** @jsx React.DOM */
|
||
|
|
||
|
var MessageBox = React.createClass({
|
||
|
render: function() {
|
||
|
return <div>{"Mr. " + this.props.name}</div>;
|
||
|
}
|
||
|
});
|
||
|
|
||
|
React.renderComponent(<MessageBox name="Zuck"/>, mountNode);
|
||
|
```
|
||
|
|
||
11 years ago
|
For more complex logic:
|
||
11 years ago
|
|
||
|
```js
|
||
|
/** @jsx React.DOM */
|
||
|
|
||
|
var MessageBox = React.createClass({
|
||
|
render: function() {
|
||
|
return <div>{this.getNameWithQualifier(this.props.name)}</div>;
|
||
|
},
|
||
|
getNameWithQualifier: function(name) {
|
||
|
return 'Mr. ' + name;
|
||
|
}
|
||
|
});
|
||
|
|
||
|
React.renderComponent(<MessageBox name="Zuck"/>, mountNode);
|
||
|
```
|