状态改变后如何路由到不同的屏幕?

时间:2018-03-19 22:54:21

标签: flutter

我正在使用flutter_redux和google_sign_in,我希望在登录后从“登录”页面路由到其他页面。

我正在使用调度LoggedInSuccessfully操作的中间件处理对Google的API调用。我知道我可以使用Navigator.pushNamed(context, "/routeName")进行实际路由,但我不熟悉Flutter和Redux,我的问题是我只是不知道 where 来调用它。

以下代码适用于GoogleAuthButtonContainer,这是我猜测路由应该在哪里。 GoogleAuthButton只是一个包含实际按钮和布局的简单小部件。

感谢任何帮助,谢谢!

  @override
  Widget build(BuildContext context) {
    return new StoreConnector<AppState, _ViewModel>(
      converter: _ViewModel.fromStore,
      builder: (BuildContext context, _ViewModel vm) {
        return new GoogleAuthButton(
          buttonText: vm.buttonText,
          onPressedCallback: vm.onPressedCallback,
        );
      },
    );
  }
}

class _ViewModel {
  final String buttonText;
  final Function onPressedCallback;

  _ViewModel({this.onPressedCallback, this.buttonText});

  static _ViewModel fromStore(Store<AppState> store) {
    return new _ViewModel(
        buttonText:
        store.state.currentUser != null ? 'Log Out' : 'Log in with Google',
        onPressedCallback: () {
          if (store.state.currentUser != null) {
            store.dispatch(new LogOut());
          } else {
            store.dispatch(new LogIn());
          }
        });
  }
}

1 个答案:

答案 0 :(得分:7)

您可以通过3种不同的方式实现这一目标:

  • 直接调用导航器(不使用ViewModel),但这不是一个干净的解决方案。
  • 设置navigatorKey并按照here
  • 所述Middleware使用它
  • 我解释的另一个解决方案是here,它将Navigator传递给Action类,并在Middleware
  • 中使用它

总而言之,您可能希望使用Middleware进行导航。