получение undefined не является функцией (оценка '(0, _reactNavigation.stacknavigator)') в навигации по ящикам - PullRequest
0 голосов
/ 20 ноября 2018

В моем приложении мне нужна навигация по ящикам, для этого я использую пример кода из this . Я интегрировал все в свое приложение, но получаю следующую ошибку

undefined не является функцией (оценивает '(0, _reactNavigation.stacknavigator)')

И установил этот тоже.

npm установить реагировать-навигация - сохранить

Но не знаю, почему возникает эта ошибка, поэтому, пожалуйста, сообщите мне, как ее устранить.

Это мой app.js

import React, { Component } from 'react';
import { StyleSheet , Platform , View , Text , Image , 
         TouchableOpacity , YellowBox } from 'react-native';
import { DrawerNavigator, StackNavigator } from 'react-navigation';

class NavigationDrawerStructure extends Component {
  //Structure for the navigatin Drawer
  toggleDrawer = () => {
    //Props to open/close the drawer
    this.props.navigationProps.toggleDrawer();
  };
  render() {
    return (
      <View style={{ flexDirection: 'row' }}>
        <TouchableOpacity onPress={this.toggleDrawer.bind(this)}>
          {/*Donute Button Image */}
          <Image
            source={require('./image/drawer.png')}
            style={{ width: 25, height: 25, marginLeft: 5 }}
          />
        </TouchableOpacity>
      </View>
    );
  }
}

class Screen1 extends Component {
  //Screen1 Component
  render() {
    return (
      <View style={styles.MainContainer}>
        <Text style={{ fontSize: 23 }}> Screen 1 </Text>
      </View>
    );
  }
}

class Screen2 extends Component {
  //Screen2 Component
  render() {
    return (
      <View style={styles.MainContainer}>
        <Text style={{ fontSize: 23 }}> Screen 2 </Text>
      </View>
    );
  }
}

class Screen3 extends Component {
  //Screen3 Component
  render() {
    return (
      <View style={styles.MainContainer}>
        <Text style={{ fontSize: 23 }}> Screen 3 </Text>
      </View>
    );
  }
}

const FirstActivity_StackNavigator = StackNavigator({
  //All the screen from the Screen1 will be indexed here 
  First: {
    screen: Screen1,
    navigationOptions: ({ navigation }) => ({
      title: 'Screen1',
      headerLeft: <NavigationDrawerStructure navigationProps={navigation} />,
      headerStyle: {
        backgroundColor: '#FF9800',
      },
      headerTintColor: '#fff',
    }),
  },
});

const Screen2_StackNavigator = StackNavigator({
  //All the screen from the Screen2 will be indexed here
  Second: {
    screen: Screen2,
    navigationOptions: ({ navigation }) => ({
      title: 'Screen2',
      headerLeft: <NavigationDrawerStructure navigationProps={navigation} />,
      headerStyle: {
        backgroundColor: '#FF9800',
      },
      headerTintColor: '#fff',
    }),
  },
});

const Screen3_StackNavigator = StackNavigator({
  //All the screen from the Screen3 will be indexed here
  Third: {
    screen: Screen3,
    navigationOptions: ({ navigation }) => ({
      title: 'Screen3',
      headerLeft: <NavigationDrawerStructure navigationProps={navigation} />,
      headerStyle: {
        backgroundColor: '#FF9800',
      },
      headerTintColor: '#fff',
    }),
  },
});

const DrawerNavigatorExample = DrawerNavigator({
  //Drawer Optons and indexing
  Screen1: { //Title
    screen: FirstActivity_StackNavigator,
  },

  Screen2: {//Title
    screen: Screen2_StackNavigator,
  },

  Screen3: {//Title
    screen: Screen3_StackNavigator,
  },
});
export default DrawerNavigatorExample;

const styles = StyleSheet.create({
  MainContainer: {
    flex: 1,
    paddingTop: 20,
    alignItems: 'center',
    marginTop: 50,
    justifyContent: 'center',
  },
});

А это package.json

{
  "name": "DrawerNavigation",
  "version": "0.0.1",
  "private": true,
  "scripts": {
    "start": "node node_modules/react-native/local-cli/cli.js start",
    "test": "jest"
  },
  "dependencies": {
    "react": "16.6.1",
    "react-native": "0.57.5",
    "react-native-vector-icons": "^6.1.0",
    "react-navigation": "^3.0.0"
  },
  "devDependencies": {
    "babel-jest": "23.6.0",
    "jest": "23.6.0",
    "metro-react-native-babel-preset": "0.49.2",
    "react-test-renderer": "16.6.1"
  },
  "jest": {
    "preset": "react-native"
  }
}

Если я буду следовать приведенному ниже образцу, также получаю ту же ошибку.

https://medium.com/@mehulmistri/drawer-navigation-with-custom-side-menu-react-native-fbd5680060ba

enter image description here

Кто-нибудь может помочь, пожалуйста

Ответы [ 10 ]

0 голосов
/ 14 июля 2019

Попробуйте с

npm, я реагирую- navigation@1.0.0-beta.23

0 голосов
/ 04 февраля 2019

Вы должны использовать React.Component вместо Component для всех классов.Я тоже столкнулся с той же проблемой, и теперь она работает с этим небольшим исправлением

class Screen2 extends React.Component {
  //Screen2 Component
  render() {
    return (
      <View style={styles.MainContainer}>
        <Text style={{ fontSize: 23 }}> Screen 2 </Text>
      </View>
    );
  }
}
0 голосов
/ 04 июня 2019
# Use of react-navigation (3.x) version ^3.0.0 #

import {
    createDrawerNavigator,
    createStackNavigator,
    createBottomTabNavigator,
    createAppContainer,
} from 'react-navigation';


const AppNavigator = createStackNavigator({
  Home: { screen: HomeScreen }
});

export default createAppContainer(AppNavigator);
0 голосов
/ 21 декабря 2018

в package.json отредактируйте реагирующую навигацию на '^ 2.17.0' СЛЕДУЮЩИЙ перезагрузите ваш компьютер

0 голосов
/ 21 января 2019

Я надеюсь, что это поможет вам, Это помогло мне!

App.js

import { createStackNavigator, createAppContainer } from 'react-navigation';
import HomeScreen from './yourScreenPath';

const AppNavigator = createStackNavigator({
  Home: { screen: HomeScreen }
});

export default createAppContainer(AppNavigator);

Проверьте ссылку: Реагируйте Навигация

0 голосов
/ 03 декабря 2018

Я наткнулся на это, потому что у меня было то же сообщение об ошибке.Кроме createStackNavigator в отличие от StackNavigator.Проблема была в том, что я обновился до 3.x, а новый в 3 - createAppContainer.

Теперь вместо

export default DrawerNavigatorExample;

вам нужно иметь

export default createAppContainer(DrawerNavigatorExample)

Надеюсь, это спасет кого-то другогоЧас, который я потратил на изучение этого: /

ссылка на документы

0 голосов
/ 22 ноября 2018

Вы можете взглянуть на этот пример кода здесь: https://snack.expo.io/@eriveltonelias/stack-actions

Я думаю, что проблема:

  1. с stackNavigator, вы должны использовать createStackNavigator (https://reactnavigation.org/docs/en/stack-navigator.html) и
  2. взамен механизма выдвижного ящика использовать createDrawerNavigator (https://reactnavigation.org/docs/en/drawer-navigator.html)
0 голосов
/ 21 ноября 2018

Эта проблема может быть из-за еще не установленной платформы Android SDK. 25 Сделайте следующее:

  1. Откройте Android Studio
  2. Откройте диспетчер SDK
  3. Нажмите вкладку Платформы SDK
  4. Выберите Android 7.1.1 (Nougat). Уровень API: 25
  5. Применить

После установки нажмите OK и попробуйте снова построить проект.

0 голосов
/ 20 ноября 2018

Заменить этот код:

import { createDrawerNavigator, createStackNavigator } from 'react-navigation';

С этим импортом вашего проекта:

import { DrawerNavigator, StackNavigator } from 'react-navigation';

Надеюсь, это поможет вам!

0 голосов
/ 20 ноября 2018

Используйте createStackNavigator вместо stackNavigator .

...