

具体情境是: app分三大模块Home主页, Bill账单和Me我的, 对应三个tab. 现在需求是 Home push HomeTwo, HomeTwo push BillTwo, BillTwo 返回到 Bill账单首页.
const Components = {
 HomeTwo: { screen: HomeTwo, path:'app/HomeTwo' },
 HomeThree: { screen: HomeThree, path:'app/HomeThree' },
 BillTwo: { screen: BillTwo, path:'app/BillTwo' },
 BillThree: { screen: BillThree, path:'app/BillThree' },
}
 
const Tabs = TabNavigator({
 Home: {
 screen: Home,
 path:'app/home',
 navigationOptions: { 
 tabBar: {
 label: '首页',
 icon: ({tintColor}) => (<Image source={require('./images/home.png')} style={[{tintColor: tintColor},styles.icon]}/>),
 },
 }
 },
 Bill: {
 screen: Bill,
 path:'app/bill',
 navigationOptions: {
 tabBar: {
 label: '账单',
 icon: ({tintColor}) => (<Image source={require('./images/bill.png')} style={[{tintColor: tintColor},styles.icon]}/>),
 },
 }
 },
 Me: {
 screen: Me,
 path:'app/me',
 navigationOptions: {
 tabBar: {
 label: '我',
 icon: ({tintColor}) => (<Image source={require('./images/me.png')} style={[{tintColor: tintColor},styles.icon]}/>),
 },
 }
 }
 }, {
 tabBarPosition: 'bottom', 
 swipeEnabled: false,
 animationEnabled: false, 
 lazyLoad: false, 
 backBehavior: 'none', 
 tabBarOptions: {
 activeTintColor: '#ff8500', 
 inactiveTintColor: '#999',
 showIcon: true, 
 indicatorStyle: {
 height: 0 
 },
 style: {
 backgroundColor: '#fff', 
 },
 labelStyle: {
 fontSize: 10, 
 },
 },
 });
 
 
 const Navs = StackNavigator({
 Home: { screen: Tabs, path:'app/Home' },
 Bill: { screen: Tabs, path:'app/Bill' },
 Me: { screen: Tabs, path:'app/Me' },
 ...Components
 }, {
 initialRouteName: 'Home', 
 navigationOptions: { 
 header: { 
 style: {
 backgroundColor: '#fff'
 },
 titleStyle: {
 color: 'green'
 }
 },
 cardStack: { 
 gesturesEnabled: true
 }
 },
 mode: 'card', 
 headerMode: 'screen'
 });在HomeTwo里使用react-navigation自带的reset action就可以重置路由信息了:
// push BillTwo
this.props.navigation.dispatch(resetAction);
 
// 使用reset action重置路由
const resetAction = NavigationActions.reset({
 index: 1, // 注意不要越界
 actions: [ // 栈里的路由信息会从 Home->HomeTwo 变成了 Bill->BillTwo
 NavigationActions.navigate({ routeName: 'Bill'}),
 NavigationActions.navigate({ routeName: 'BillTwo'})
 ]
});从HomeTwo push 到 BillTwo页面后, 点击BillTwo的左上角导航按钮返回就能返回到Bill账单首页了.
相信看了以上介绍你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!
相关阅读:
驼峰命名与JS的问题解答
JS里的布尔值、关系运算符、逻辑运算符的详解及实例
js代码案列-根据日期计算星期几
