import React, { Component, PropTypes } from 'react' async function load() { return [ { id: 1, name: '1' }, { id: 2, name: '2' }, { id: 3, name: '3' }, { id: 4, name: '4' } ]; } export default class extends Component { static propTypes = { onReady: PropTypes.func.isRequired } constructor(props) { super(props); this.state = { users: [] }; } async componentDidMount() { const users = await load(); this.setState({ users }); } componentDidUpdate() { this.props.onReady(); } render() { return ( <div id="feature-async-await"> {this.state.users.map(user => ( <div key={user.id}>{user.name}</div> ))} </div> ); } }