如何在颤动中推动替换删除整个导航堆栈?

Posted

技术标签:

【中文标题】如何在颤动中推动替换删除整个导航堆栈?【英文标题】:How to push replacement removing whole navigation stack in flutter? 【发布时间】:2020-06-23 00:26:57 【问题描述】:

我有我的主页,我可以从中转到我的 Flutter 应用程序中的个人资料页面。在按下个人资料图标时,我将上下文推送到个人资料页面,其中有一个更改密码的按钮。当我按下更改密码时,它会打开一个警告对话框,其中包含输入密码的文本字段。我有一个注销功能,它通过清除首选项并将上下文推送到登录屏幕作为替换来注销应用程序。现在我想在更改密码时注销我的应用程序。但它将替换推送到导航堆栈的顶部,导航堆栈返回堆栈内的登录页面。我该如何解决这个问题?

_changePassword() async
    print(widget.id);
    var data = 
      "newPassword": _passcontroller.text,
      "confirmNewPassword": _confirmpasscontroller.text
    ;
    var res = await CallApi().putData(data, 'users/$widget.id/password/change');
    var response = res.data;
    print(response);
    if (response['success']) 
      showSimpleFlushbar(context, 'Password Changed Successfully.');
      logout(context);
    
  

【问题讨论】:

【参考方案1】:

使用这个:

它删除了以前的所有导航并带您到登录页面(第一页)。

()=> Navigator.pushAndRemoveUntil(
                  context,
                  MaterialPageRoute(builder: (BuildContext context) => LoginPage()),
                  ModalRoute.withName('/'),
                )

它将删除以前的整个导航。

//Use this for logout

 Navigator.pushAndRemoveUntil(
                  context,
                  MaterialPageRoute(builder: (BuildContext context) => LoginPage()),
                 (Route<dynamic> route) => false
                );
//OR

 Navigator.of(context).pushNamedAndRemoveUntil('/landingpage', (Route<dynamic> route) => false);

【讨论】:

【参考方案2】:

使用此代码删除 Flutter 中的整个导航堆栈

Navigator.of(context).pushAndRemoveUntil(MaterialPageRoute(builder: (context) =>
                    ClassName()), (Route<dynamic> route) => false);

【讨论】:

以上是关于如何在颤动中推动替换删除整个导航堆栈?的主要内容,如果未能解决你的问题,请参考以下文章

如何在颤动中从导航器堆栈中弹出最后三个路由

每次当前选项卡在 TabBar 颤动中更改时,如何将新页面添加到导航器堆栈?

在颤动中用参数推动替换的最佳方法是啥?

如何在导航控制器中关闭视图控制器,而不关闭整个堆栈

如何在颤动中获取堆栈内容器的固有大小

如何在颤动中删除蜂巢中的所有框?