Android OS 后退按钮带我回到 Expo 项目屏幕 [英] Android OS back button takes me back to Expo projects screen

查看:13
本文介绍了Android OS 后退按钮带我回到 Expo 项目屏幕的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

Firstly, I have a React Native app built using Expo and utilising React Navigation for routing.

I'm using a SwitchNavigator to switch between two stack navigators which represent my authorisation workflow (my screens before I've logged in) and my app workflow (the screens after I've logged in) and it looks something like this.

const AppStack = createStackNavigator({ Home: HomeScreen, Second: SecondScreen, HouseDetail: HouseDetailScreen, Camera: CameraScreen}
);
const AuthStack = createStackNavigator({ Login: LoginScreen }
);

export default createSwitchNavigator(
  {
    AuthLoading: AuthLoadingScreen,
    App: AppStack,
    Auth: AuthStack,
  },
  {
    initialRouteName: 'AuthLoading'


  }
);

My problem is that the behaviour of the back button in Android does not behave properly.

Here is a scenario. I've just logged in, and I'm in the App stack's HomeScreen page. I will navigate to the SecondScreen using

this.props.navigation.navigate('Second')

At this point, I would imagine that if I hit the back button, I should go back to the HomeScreen.

However, when I press the back button (the one built into the OS), I get taken out of my app and into the Expo projects list.

If I run this.props.navigation.goBack() though, then it works as expected and I'm back at the home screen.

Why is this happening? Is this an Expo thing?

解决方案

Ok, so this was hours of time I'll never get back.

Turns out this is an issue with the latest version of Firebase.

https://github.com/react-navigation/react-navigation/issues/1603

The solution is to downgrade to 5.0.3 and this worked for me.

这篇关于Android OS 后退按钮带我回到 Expo 项目屏幕的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆