Browse Source

Docs to ES6: Displaying data example.

main
gillchristian 9 years ago
committed by Dan Abramov
parent
commit
5e59a1fcd9
  1. 12
      docs/02-displaying-data.md
  2. 63
      docs/04-multiple-components.md

12
docs/02-displaying-data.md

@ -36,8 +36,8 @@ Let's look at a really simple example. Create a `hello-react.html` file with the
For the rest of the documentation, we'll just focus on the JavaScript code and assume it's inserted into a template like the one above. Replace the placeholder comment above with the following JSX: For the rest of the documentation, we'll just focus on the JavaScript code and assume it's inserted into a template like the one above. Replace the placeholder comment above with the following JSX:
```javascript ```javascript
var HelloWorld = React.createClass({ class HelloWorld extends React.Component {
render: function() { render() {
return ( return (
<p> <p>
Hello, <input type="text" placeholder="Your name here" />! Hello, <input type="text" placeholder="Your name here" />!
@ -45,14 +45,16 @@ var HelloWorld = React.createClass({
</p> </p>
); );
} }
}); }
setInterval(function() { function tick() {
ReactDOM.render( ReactDOM.render(
<HelloWorld date={new Date()} />, <HelloWorld date={new Date()} />,
document.getElementById('example') document.getElementById('example')
); );
}, 500); }
setInterval(tick, 500);
``` ```
## Reactive Updates ## Reactive Updates

63
docs/04-multiple-components.md

@ -17,8 +17,8 @@ By building modular components that reuse other components with well-defined int
Let's create a simple Avatar component which shows a Facebook page picture and name using the Facebook Graph API. Let's create a simple Avatar component which shows a Facebook page picture and name using the Facebook Graph API.
```javascript ```javascript
var Avatar = React.createClass({ class Avatar extends React.Component {
render: function() { render() {
return ( return (
<div> <div>
<PagePic pagename={this.props.pagename} /> <PagePic pagename={this.props.pagename} />
@ -26,25 +26,25 @@ var Avatar = React.createClass({
</div> </div>
); );
} }
}); }
var PagePic = React.createClass({ class PagePic extends React.Component {
render: function() { render() {
return ( return (
<img src={'https://graph.facebook.com/' + this.props.pagename + '/picture'} /> <img src={'https://graph.facebook.com/' + this.props.pagename + '/picture'} />
); );
} }
}); }
var PageLink = React.createClass({ class PageLink extends React.Component {
render: function() { render() {
return ( return (
<a href={'https://www.facebook.com/' + this.props.pagename}> <a href={'https://www.facebook.com/' + this.props.pagename}>
{this.props.pagename} {this.props.pagename}
</a> </a>
); );
} }
}); }
ReactDOM.render( ReactDOM.render(
<Avatar pagename="Engineering" />, <Avatar pagename="Engineering" />,
@ -110,13 +110,12 @@ In most cases, this can be sidestepped by hiding elements instead of destroying
The situation gets more complicated when the children are shuffled around (as in search results) or if new components are added onto the front of the list (as in streams). In these cases where the identity and state of each child must be maintained across render passes, you can uniquely identify each child by assigning it a `key`: The situation gets more complicated when the children are shuffled around (as in search results) or if new components are added onto the front of the list (as in streams). In these cases where the identity and state of each child must be maintained across render passes, you can uniquely identify each child by assigning it a `key`:
```javascript ```javascript
render: function() { render() {
var results = this.props.results;
return ( return (
<ol> <ol>
{results.map(function(result) { {this.props.results.map((result) => (
return <li key={result.id}>{result.text}</li>; <li key={result.id}>{result.text}</li>
})} ))}
</ol> </ol>
); );
} }
@ -128,41 +127,41 @@ The `key` should *always* be supplied directly to the components in the array, n
```javascript ```javascript
// WRONG! // WRONG!
var ListItemWrapper = React.createClass({ class ListItemWrapper extends React.Component {
render: function() { render() {
return <li key={this.props.data.id}>{this.props.data.text}</li>; return <li key={this.props.data.id}>{this.props.data.text}</li>;
} }
}); }
var MyComponent = React.createClass({ class MyComponent extends React.Component {
render: function() { render() {
return ( return (
<ul> <ul>
{this.props.results.map(function(result) { {this.props.results.map((result) => (
return <ListItemWrapper data={result}/>; <ListItemWrapper data={result} />
})} )}
</ul> </ul>
); );
} }
}); }
``` ```
```javascript ```javascript
// Correct :) // Correct :)
var ListItemWrapper = React.createClass({ class ListItemWrapper extends React.Component {
render: function() { render() {
return <li>{this.props.data.text}</li>; return <li>{this.props.data.text}</li>;
} }
}); }
var MyComponent = React.createClass({ class MyComponent extends React.Component {
render: function() { render() {
return ( return (
<ul> <ul>
{this.props.results.map(function(result) { {this.props.results.map((result) => (
return <ListItemWrapper key={result.id} data={result}/>; <ListItemWrapper key={result.id} data={result} />
})} )}
</ul> </ul>
); );
} }
}); }
``` ```
You can also key children by passing a ReactFragment object. See [Keyed Fragments](create-fragment.html) for more details. You can also key children by passing a ReactFragment object. See [Keyed Fragments](create-fragment.html) for more details.

Loading…
Cancel
Save