@ -292,8 +292,8 @@ So far we've been inserting the comments directly in the source code. Instead, l
```javascript
```javascript
// tutorial8.js
// tutorial8.js
var data = [
var data = [
{author: "Pete Hunt", text: "This is one comment"},
{id: 1, author: "Pete Hunt", text: "This is one comment"},
{author: "Jordan Walke", text: "This is *another* comment"}
{id: 2, author: "Jordan Walke", text: "This is *another* comment"}
];
];
```
```
@ -327,7 +327,7 @@ var CommentList = React.createClass({
render: function() {
render: function() {
var commentNodes = this.props.data.map(function(comment) {
var commentNodes = this.props.data.map(function(comment) {
return (
return (
<Commentauthor={comment.author}>
<Commentauthor={comment.author}key={comment.id}>
{comment.text}
{comment.text}
</Comment>
</Comment>
);
);
@ -659,7 +659,7 @@ var CommentBox = React.createClass({
Our application is now feature complete but it feels slow to have to wait for the request to complete before your comment appears in the list. We can optimistically add this comment to the list to make the app feel faster.
Our application is now feature complete but it feels slow to have to wait for the request to complete before your comment appears in the list. We can optimistically add this comment to the list to make the app feel faster.
```javascript{17-19}
```javascript{17-23}
// tutorial20.js
// tutorial20.js
var CommentBox = React.createClass({
var CommentBox = React.createClass({
loadCommentsFromServer: function() {
loadCommentsFromServer: function() {
@ -677,6 +677,10 @@ var CommentBox = React.createClass({
},
},
handleCommentSubmit: function(comment) {
handleCommentSubmit: function(comment) {
var comments = this.state.data;
var comments = this.state.data;
// Optimistically set an id on the new comment. It will be replaced by an
// id generated by the server. In a production application you would likely
// not use Date.now() for this and would have a more robust system in place.