Fetch data in componentDidMount
. When the response arrives, store the data in state, triggering a render to update your UI.
When fetching data asynchronously, use componentWillUnmount
to cancel any outstanding requests before the component is unmounted.
This example fetches the desired Github user's latest gist:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | var UserGist = React.createClass({ getInitialState: function () { return { username: '' , lastGistUrl: '' }; }, componentDidMount: function () { this .serverRequest = $.get( this .props.source, function (result) { var lastGist = result[0]; this .setState({ username: lastGist.owner.login, lastGistUrl: lastGist.html_url }); }.bind( this )); }, componentWillUnmount: function () { this .serverRequest.abort(); }, render: function () { return ( <div> { this .state.username}'s last gist is <a href={ this .state.lastGistUrl}>here</a>. </div> ); } }); ReactDOM.render( mountNode ); |
Please login to continue.