清除堆栈导航到React-Navigation

问题描述 投票:1回答:1

我的react-native应用程序包含一个包含多个StackNavigators的DrawerNavigator。我的结构的简化示例如下所示

- Drawer
  - Stack 1
    - Screen 1
    - Screen 2
  - Stack 2
    - Screen 1
    - Screen 2

我的问题如下:我在Stack 1的屏幕1上。我使用Drawer导航到Stack 2的屏幕1。从Stack 2的屏幕1开始,我只需按一下按钮即可导航到Stack 2的屏幕2。然后我使用抽屉导航回堆栈1。我再次使用抽屉返回堆栈2。我现在在Stack 2的屏幕1上,但是标题中有一个后退按钮,看来我的当前屏幕刚刚放在旧堆栈的顶部。按下它导航到Stack 2的屏幕2,然后再次按下它导航到Stack 2的屏幕1。

当导航回到抽屉中的堆栈时,我希望它能够使用新堆栈将我返回到堆栈中的第一个项目 - 也就是说,没有后退按钮。

这种行为有望吗?如果是这样的话,当我从抽屉导航到堆栈时,我能做些什么来“清除”堆栈吗?

这是一个世博会的例子,只有极少的代码来重现我的结构和问题:https://snack.expo.io/rk2HV-HNf

react-native react-navigation
1个回答
0
投票

在反应导航中,如果您想要返回,而不是创建新屏幕,则需要使用this.props.navigation.goBack()。如果你使用navigate方法,它会创建一个新的屏幕,因此返回按钮。

但是,还有另一种方式。在您的情况下,您不需要这个,但是您也可以使用NavigationActions从头开始定义堆栈并将其分配给重置导航堆栈。

© www.soinside.com 2019 - 2024. All rights reserved.