You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
56 lines
1.1 KiB
56 lines
1.1 KiB
7 years ago
|
// After
|
||
|
class ExampleComponent extends React.Component {
|
||
|
state = {
|
||
|
externalData: null,
|
||
|
};
|
||
|
|
||
|
// highlight-range{1-13}
|
||
|
static getDerivedStateFromProps(nextProps, prevState) {
|
||
|
// Store prevId in state so we can compare when props change.
|
||
|
// Clear out previously-loaded data (so we don't render stale stuff).
|
||
|
if (nextProps.id !== prevState.prevId) {
|
||
|
return {
|
||
|
externalData: null,
|
||
|
prevId: nextProps.id,
|
||
|
};
|
||
|
}
|
||
|
|
||
|
// No state update necessary
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
componentDidMount() {
|
||
|
this._loadAsyncData();
|
||
|
}
|
||
|
|
||
|
// highlight-range{1-5}
|
||
|
componentDidUpdate(prevProps, prevState) {
|
||
|
if (prevState.externalData === null) {
|
||
|
this._loadAsyncData();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
componentWillUnmount() {
|
||
|
if (this._asyncRequest) {
|
||
|
this._asyncRequest.cancel();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
render() {
|
||
|
if (this.state.externalData === null) {
|
||
|
// Render loading state ...
|
||
|
} else {
|
||
|
// Render real UI ...
|
||
|
}
|
||
|
}
|
||
|
|
||
|
_loadAsyncData() {
|
||
|
this._asyncRequest = asyncLoadData(this.props.id).then(
|
||
|
externalData => {
|
||
|
this._asyncRequest = null;
|
||
|
this.setState({externalData});
|
||
|
}
|
||
|
);
|
||
|
}
|
||
|
}
|