首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >AtlasKit表单提交方法中的状态变更问题

AtlasKit表单提交方法中的状态变更问题
EN

Stack Overflow用户
提问于 2019-04-18 09:57:36
回答 1查看 195关注 0票数 1

在Atlaskit FormForm方法中,我希望更改状态属性的值,该值将导致表单被隐藏:

代码语言:javascript
复制
<Form onSubmit={data => {
    return new Promise(resolve => {
        setShowForm(false);
        resolve();
    })
  }}>
</Form>

但是,这会导致一个反应错误:

无法对未挂载的组件执行响应状态更新。这是一个非操作,但它表示您的应用程序中存在内存泄漏。若要修复,请取消componentWillUnmount方法中的所有订阅和异步任务。

当我稍后设置该值时,错误将消失:

代码语言:javascript
复制
setTimeout(() => setShowForm(false));

因此,很明显,当我改变状态时,表单仍然在卸载(虽然我不知道这会对表单产生什么影响,但我对反应还不太熟悉)。我在这里应该采取什么方法?

EN

回答 1

Stack Overflow用户

发布于 2019-04-18 10:07:43

这是因为您向API发出了异步请求,请求(例如诺言)尚未得到解决,但您需要卸载组件。

您可以通过维护一个标志来解决这个问题,比如_isMounted,查看组件是否已卸载,并根据承诺解析更改标志值。

//示例代码

代码语言:javascript
复制
class Form extends Component {
  _isMounted = false;

  constructor(props) {
    super(props);

    this.state = {
      data: [],
    };
  }

  componentDidMount() {
    this._isMounted = true;

    axios
      .get('my_api_url')
      .then(result => {
        if (this._isMounted) {
          this.setState({
            data: result.data.data,
          });
        }
      });
  }

  componentWillUnmount() {
    this._isMounted = false;
  }

  render() {
    ...
  }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55743592

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档