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.
41 lines
813 B
41 lines
813 B
// Before
|
|
class ExampleComponent extends React.Component {
|
|
state = {
|
|
externalData: null,
|
|
};
|
|
|
|
componentDidMount() {
|
|
this._loadAsyncData(this.props.id);
|
|
}
|
|
|
|
// highlight-range{1-6}
|
|
componentWillReceiveProps(nextProps) {
|
|
if (nextProps.id !== this.props.id) {
|
|
this.setState({externalData: null});
|
|
this._loadAsyncData(nextProps.id);
|
|
}
|
|
}
|
|
|
|
componentWillUnmount() {
|
|
if (this._asyncRequest) {
|
|
this._asyncRequest.cancel();
|
|
}
|
|
}
|
|
|
|
render() {
|
|
if (this.state.externalData === null) {
|
|
// Render loading state ...
|
|
} else {
|
|
// Render real UI ...
|
|
}
|
|
}
|
|
|
|
_loadAsyncData(id) {
|
|
this._asyncRequest = loadMyAsyncData(id).then(
|
|
externalData => {
|
|
this._asyncRequest = null;
|
|
this.setState({externalData});
|
|
}
|
|
);
|
|
}
|
|
}
|
|
|