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.
39 lines
929 B
39 lines
929 B
// After
|
|
class ExampleComponent extends React.Component {
|
|
// highlight-range{1-4}
|
|
state = {
|
|
subscribedValue: this.props
|
|
.dataSource.value,
|
|
};
|
|
|
|
// highlight-range{1-19}
|
|
componentDidMount() {
|
|
// Event listeners are only safe to add after mount,
|
|
// So they won't leak if mount is interrupted or errors.
|
|
this.props.dataSource.subscribe(
|
|
this._onSubscriptionChange
|
|
);
|
|
|
|
// External values could change between render and mount,
|
|
// In some cases it may be important to handle this case.
|
|
if (
|
|
this.state.subscribedValue !==
|
|
this.props.dataSource.value
|
|
) {
|
|
this.setState({
|
|
subscribedValue: this.props
|
|
.dataSource.value,
|
|
});
|
|
}
|
|
}
|
|
|
|
componentWillUnmount() {
|
|
this.props.dataSource.unsubscribe(
|
|
this._onSubscriptionChange
|
|
);
|
|
}
|
|
|
|
_onSubscriptionChange = subscribedValue => {
|
|
this.setState({subscribedValue});
|
|
};
|
|
}
|
|
|