微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ios – React Native – 在异步操作后导航

我正在使用React Native和Redux开发移动应用程序,我正面临着软件设计问题.
我想调用REST API(异步操作)进行登录,如果该操作成功,则导航到主视图.
我正在使用redux和thunk所以我已经实现了异步操作,所以我的主要疑问是:我应该把逻辑导航到主视图?

我可以直接从动作访问导航器对象并在那里执行导航吗?
我应该在登录组件中执行此操作吗? (正如我已经这样做 – 检查下面的代码).

componentwillReceiveProps(nextProps){
    if(nextProps.errorLoginMsg){
        Alert.alert("Login Failed",nextProps.errorLoginMsg);
    }
    else if(!nextProps.user.isNull()){
      this.props.navigator.replace({name: 'main'});
    }
  }

我对组件中的逻辑没有信心.似乎不是一个好习惯.有没有其他方法可以做到这一点?

谢谢

解决方法

这是使用当前Navigator API进行本地反应时最难的问题之一.我建议有一个路由存储,它保存当前路由,并且包含连接到该存储的导航器的组件,并在componentwillReceiveProps上触发导航.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐