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

Zer*_*ive 3 navigation dart flutter

我有我的主页,我可以从中转到我的 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);
    }
  }
Run Code Online (Sandbox Code Playgroud)

小智 8

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

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


Shr*_*rma 7

用这个:

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

()=> Navigator.pushAndRemoveUntil(
                  context,
                  MaterialPageRoute(builder: (BuildContext context) => LoginPage()),
                  ModalRoute.withName('/'),
                )
Run Code Online (Sandbox Code Playgroud)

或者

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

//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);

Run Code Online (Sandbox Code Playgroud)