【问题标题】:Expo app crashes only in Android when trying to navigate from a screen to the other using a Button尝试使用按钮从一个屏幕导航到另一个屏幕时,Expo 应用程序仅在 Android 中崩溃
【发布时间】:2019-10-28 17:53:21
【问题描述】:

我在 react native 中创建了一个堆栈导航器,然后使用它从我的主屏幕使用一个按钮转到下一个屏幕,当单击该按钮时我正在调用

props.navigation.navigate('SS2');

SS2 是我想去的画面。

这在使用 expo 运行应用程序的 iOS 中运行良好,但对于 android 则不是这样,我尝试了 Android v8.0 和 v9.0,在单击按钮后,这两个 expo 都崩溃了。

博览会服务器/终端没有抛出错误消息,应用程序只是崩溃并自行关闭。

这是您可以运行和模拟问题的项目:

https://snack.expo.io/SkYyYFH5B

这是我正在使用的 .js 文件:

package.json

   {
  "main": "node_modules/expo/AppEntry.js",
  "scripts": {
    "start": "expo start",
    "android": "expo start --android",
    "ios": "expo start --ios",
    "web": "expo start --web",
    "eject": "expo eject"
  },
  "dependencies": {
    "expo": "^35.0.0",
    "expo-linear-gradient": "^7.0.1",
    "native-base": "^2.13.8",
    "package.json": "^2.0.1",
    "react": "16.8.3",
    "react-dom": "16.8.3",
    "react-native": "https://github.com/expo/react-native/archive/sdk-35.0.0.tar.gz",
    "react-native-elements": "^1.2.6",
    "react-native-fs": "^2.16.1",
    "react-native-gesture-handler": "^1.4.1",
    "react-native-ionicons": "^4.6.3",
    "react-native-vector-icons": "^6.6.0",
    "react-native-web": "^0.11.7",
    "react-navigation": "^4.0.10",
    "react-navigation-stack": "^1.10.3"
  },
  "devDependencies": {
    "babel-preset-expo": "^7.1.0"
  },
  "private": true
}

App.js

import React from 'react';

import MainNavigator from './navigation/SingUpNavigator';

export default class App extends React.Component {
  render() {
    return (
      <MainNavigator />
    );
  }
}

SingUpNavigator.js

import React from 'react';
import { createAppContainer } from 'react-navigation';
import { createStackNavigator } from 'react-navigation-stack';

import LoginRegisterScreen from '../screens/LoginRegisterScreen';
import SS2 from '../screens/register/SS2';

const MainNavigator = createStackNavigator(
    {
      Home: {
        screen: LoginRegisterScreen
      },
      LoginRegisterScreen: {
        screen: LoginRegisterScreen
      },
      SS2: {
        screen: SS2
      }
    },
    {
      headerMode: 'none'
    }
  )

  export default createAppContainer(MainNavigator);

LoginRegisterScreen.js

 ... 
<MainButton title="REGISTER" onPress={() => { props.navigation.navigate('SS2')}}/>;
 ...

【问题讨论】:

  • 你能在https://expo.io上重现这个问题吗?
  • 在发布问题时遵循本指南很有用:hhttps://stackoverflow.com/help/mcve
  • @nikolai-serg 是的,这是链接:snack.expo.io/SkYyYFH5B。当您单击 Android 时,“REGISTER”按钮博览会会崩溃,当您在 iOS 中单击它时它会工作,它会导航到“SS2”屏幕。

标签: android react-native react-navigation expo react-native-navigation


【解决方案1】:

此错误不是由导航引起的,而是在SS2 屏幕上发生的。

您不应该像您的代码一样使用这种flex center 样式。

<View flex center style={styles.firstView}>

</View>

你可以用这种风格代替

style = {
  flexDirection: 'row',
  justifyContent: 'center'
}

我更新了你的代码。 https://snack.expo.io/@angelsinej/github.com-arditshala-seatr-demo:mobile

【讨论】:

  • 嗨,我有一个关于上述问题的问题,所以基本上使用他们的初始不是应该打印出错误吗?
  • 我遇到了类似的问题,应用程序由于样式而崩溃.. 有趣
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-10-01
  • 2010-11-09
  • 1970-01-01
  • 1970-01-01
  • 2020-06-14
  • 2011-09-25
相关资源
最近更新 更多