Files
react.dev/examples/update-on-async-rendering/fetching-external-data-after.js
Brian Vaughn 813be17f1e Updated docs/recipes in response to a new GH question
This question showed there was a use-case that I wasn't covering fully enough before, so I've added a new section.
2018-02-14 14:34:14 -08:00

31 lines
562 B
JavaScript

// After
class ExampleComponent extends React.Component {
state = {
externalData: null,
};
// highlight-range{1-8}
componentDidMount() {
this._asyncRequest = asyncLoadData().then(
externalData => {
this._asyncRequest = null;
this.setState({externalData});
}
);
}
componentWillUnmount() {
if (this._asyncRequest) {
this._asyncRequest.cancel();
}
}
render() {
if (this.state.externalData === null) {
// Render loading state ...
} else {
// Render real UI ...
}
}
}