In a world where this component was server-rendered, we wouldn't want to call the data-fetching code there so it makes more sense to have it in componentDidMount.
@ -386,7 +386,7 @@ var CommentBox = React.createClass({
getInitialState: function() {
getInitialState: function() {
return {data: []};
return {data: []};
},
},
componentWillMount: function() {
componentDidMount: function() {
$.ajax({
$.ajax({
url: this.props.url,
url: this.props.url,
dataType: 'json',
dataType: 'json',
@ -410,7 +410,7 @@ var CommentBox = React.createClass({
});
});
```
```
Here, `componentWillMount` is a method called automatically by React before a component is rendered. The key to dynamic updates is the call to `this.setState()`. We replace the old array of comments with the new one from the server and the UI automatically updates itself. Because of this reactivity, it is only a minor change to add live updates. We will use simple polling here but you could easily use WebSockets or other technologies.
Here, `componentDidMount` is a method called automatically by React when a component is rendered. The key to dynamic updates is the call to `this.setState()`. We replace the old array of comments with the new one from the server and the UI automatically updates itself. Because of this reactivity, it is only a minor change to add live updates. We will use simple polling here but you could easily use WebSockets or other technologies.
```javascript{3,19-20,34}
```javascript{3,19-20,34}
// tutorial14.js
// tutorial14.js
@ -430,7 +430,7 @@ var CommentBox = React.createClass({