React Navigation - createStackNavigator错误 - "未定义不是函数"

mta*_*ash 5 javascript react-native react-navigation

我已创建以下代码以导入app.js

import React from "react";
import { View } from "react-native";
import { createStackNavigator } from "react-navigation";
import HomeScreen from '../screens/HomeScreen';
import ProfileScreen from '../screens/auth/ProfileScreen';
import FilterScreen from '../screens/FilterScreen';

  const Routes = createStackNavigator(
      {
        Home: {
          screen: HomeScreen
        },
        Filters: {
          screen: FilterScreen
        },
        Profile: {
          screen: ProfileScreen
        }
      },
      {
        initialRouteName: "Home",
        navigationOptions: {
          headerTitleStyle: {
            fontWeight: "bold",
            color: "#fff",
          },
          headerTintColor: "#fff"
        }
      }
    );

    export default Routes;
Run Code Online (Sandbox Code Playgroud)

我正在导入app.js,如下所示

import Routes from './navigation/StackNavigator';
Run Code Online (Sandbox Code Playgroud)

当我在此阶段预览我的应用程序时,收到以下错误:

undefined is not a function (near '...(0, 

_reactNavigation.createStackNavigator)...')

<unknown>
    C:\Apps\test\app\navigation\StackNavigator.js:9:6
loadModuleImplementation
    C:\Apps\test\app\node_modules\metro\src\lib\polyfills\require.js:213:12
<unknown>
    C:\Apps\test\app\App.js:7
loadModuleImplementation
    C:\Apps\test\app\node_modules\metro\src\lib\polyfills\require.js:213:12
<unknown>
    C:\Apps\test\app\node_modules\expo\AppEntry.js:2
loadModuleImplementation
    C:\Apps\test\app\node_modules\metro\src\lib\polyfills\require.js:213:12
guardedLoadModule
    C:\Apps\test\app\node_modules\metro\src\lib\polyfills\require.js:140:45
global code
    <unknown file>:0
Run Code Online (Sandbox Code Playgroud)

有谁知道什么可能是错的?我正在撕扯我的头发!任何建议都将非常感谢!

dra*_*vic 0

建议:

  • 将路由重命名为其他名称,例如Routes1(在 和app.jsnavigation/StackNavigator
  • 缩小错误的范围,例如删除选项createStackNavigator并尝试以下操作:

    const Routes1 = createStackNavigator();

    export default Routes1;

  • 尝试此文件中的选项卡导航器(而不是 stackNavigator),看看它是否正常工作。

  • 清理并强制重新安装模块