我观察到后退按钮逻辑可以看到堆栈中的屏幕序列。我在堆栈导航器中放置了一个抽屉导航器。
在堆栈顶部,我有启动画面。在仪表板上,当我按下后退按钮时,我需要启动屏幕。
进入应用程序后如何从堆栈中删除启动画面,所以当我按下后退按钮仪表板时,它将退出应用程序而不是进入启动画面。
/* @flow */
import React from "react";
import { Platform, Text } from "react-native";
import { Root } from "native-base";
import { StackNavigator, DrawerNavigator} from "react-navigation";
import Register from "./components/Register";
import Available from "./components/Available";
import Splash from "./components/splash/“;
import SideBar from "./components/sidebar";
import Discover from "./components/Discover/";
import Dashboard from "./components/Dashboard/";
import Contact from "./components/Contact"
const Drawer = DrawerNavigator(
{
Dashboard: { screen: Dashboard },
Discover: { screen: Discover },
Contact: { screen: Contact},
},
{
navigationOptions: {
gesturesEnabled: false,
},
initialRouteName: "Dashboard",
contentOptions: {
activeTintColor: "#e91e63"
},
drawerPosition: 'right',
contentComponent: props => <SideBar {...props} />
}
);
const AppNavigator = StackNavigator(
{
Splash: { screen: Splash },
Drawer: { screen: Drawer },
Available: { screen: Available },
Register: { screen: Register },
},
{
// initialRouteName: “Splash”,
headerMode: "none",
}
);
export default () =>
<Root>
<AppNavigator />
</Root>;
原文由 devedv 发布,翻译遵循 CC BY-SA 4.0 许可协议
一种解决方案是重置初始屏幕组件内的堆栈并将用户重定向到您喜欢的屏幕:
对于较新版本的
react-navigation
:链接到官方文档