【发布时间】:2018-11-15 22:50:20
【问题描述】:
在我的很多组件中,我需要做这样的事情:
handleSubmit() {
this.setState({loading: true})
someAsyncFunc()
.then(() => {
return this.props.onSuccess()
})
.finally(() => this.setState({loading: false}))
}
onSuccess 函数
- 可能是也可能不是一个承诺(如果是,
loading应该保持真实,直到它被解决) - 可能会或可能不会卸载组件(它可能会关闭此组件所在的模式,甚至导航到不同的页面)
如果函数卸载组件,this.setState({loading: false})显然会触发警告Can't call setState (or forceUpdate) on an unmounted component.
我的两个问题:
- 是否有避免该问题的简单方法?我不想在
componentDidMount和componentWillUnmount中设置一些_isMounted变量,然后在我的大多数组件中需要时检查它,另外我可能会在下次写这样的东西时忘记这样做......李> - 真的有问题吗?我知道,根据警告
it indicates a memory leak in my application,但在这种情况下它不是内存泄漏,是吗?也许忽略警告就可以了...
编辑:第二个问题对我来说比第一个问题更重要。如果这确实是一个问题,并且我不能在未安装的组件上调用setState,我可能会自己找到一些解决方法。但是我很好奇我是否不能忽略它。
问题的实例:
const someAsyncFunc = () => new Promise(resolve => {
setTimeout(() => {
console.log("someAsyncFunc resolving");
resolve("done");
}, 2000);
});
class Example extends React.Component {
constructor(...args) {
super(...args);
this.state = {loading: false};
}
componentDidMount() {
setTimeout(() => this.handleSubmit(), 100);
}
handleSubmit() {
this.setState({loading: true})
someAsyncFunc()
/*
.then(() => {
return this.props.onSuccess()
})
*/
.finally(() => this.setState({loading: false}))
}
render() {
return <div>{String(this.state.loading)}</div>;
}
}
class Wrapper extends React.Component {
constructor(props, ...rest) {
super(props, ...rest);
this.state = {
children: props.children
};
}
componentDidMount() {
setTimeout(() => {
console.log("removing");
this.setState({children: []});
}, 1500)
}
render() {
return <div>{this.state.children}</div>;
}
}
ReactDOM.render(
<Wrapper>
<Example />
</Wrapper>,
document.getElementById("root")
);
.as-console-wrapper {
max-height: 100% !important;
}
<div id="root"></div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.js"></script>
【问题讨论】:
-
在组件模态关闭和导航中,为什么需要加载false?反正与之关联的状态会被销毁
-
@RIYAJKHAN 正如我所写:
onSuccess函数可能会或可能不会卸载组件 - 在某些情况下,模态应该保持打开状态,当然不会加载.. .
标签: javascript reactjs promise