reactjs - 世博会应用程序 : The action 'TOGGLE_DRAWER' was not handled by any navigator

标签 reactjs react-native expo react-navigation

我试图从 MealsNavigator 导航中显示一个抽屉。

到目前为止,我导入了 ff 必需品:

import React from 'react';
import { NavigationContainer } from '@react-navigation/native';
import { createStackNavigator } from '@react-navigation/stack';
import { createDrawerNavigator } from '@react-navigation/drawer';
import { DrawerActions } from '@react-navigation/native';

然后在我的代码中,我尝试通过 navigation.dispatch(DrawerActions.toggleDrawer()); 调用抽屉切换开关:

const MealsNav = createStackNavigator();

const MealsNavigator = () => {
    return (
        <MealsNav.Navigator
            mode="modal"
            screenOptions={{
                headerStyle: {
                    backgroundColor: Colors.primaryColor,
                },
                headerTintColor: '#fff',
                headerTitleStyle: {
                    fontSize: 17
                }
            }}
        >
          <MealsNav.Screen
                name="Categories"
                component={CategoriesScreen}
                options={({ navigation, route }) => ({
                    title: 'Meals Categories',
                    headerLeft: () => (
                        <HeaderButtons HeaderButtonComponent={HeaderButton}>
                            <Item
                                title='Menu'
                                iconName='ios-menu'
                                // I CALLED IT HERE ----->>>>>
                                onPress={() => {
                                    navigation.dispatch(DrawerActions.toggleDrawer());
                                }}
                            />
                        </HeaderButtons>
                    )
          })}
        />
            <MealsNav.Screen
                name="CategoryMeals"
                component={CategoryMealsScreen}
                options={({ route }) => {
                    const catId = route.params.categoryId;
                    const selectedCategory = CATEGORIES.find((cat) => cat.id === catId);

                    return {
                        title: selectedCategory.title,
                    };

                }}
            />
            <MealsNav.Screen
                name="MealDetail"
                component={MealDetailScreen}
                options={{
                    title: 'Meal Detail',
                    headerRight: () => (
                        <HeaderButtons HeaderButtonComponent={HeaderButton}>
                            <Item
                                title='Favorite'
                                iconName='ios-menu'
                                onPress={() => console.log('Mark as the favorite')}
                            />
                        </HeaderButtons>
                    ),
                }}
            />
        </MealsNav.Navigator>
    );
};

这是我的抽屉导航代码:

const mainNavigator = createDrawerNavigator();

const MainNavigatorDrawer = () => {
    return (
      <NavigationContainer>
        <mainNavigator.Screen name="MealsFav" component={MealsFavTabNavigator} />
        <mainNavigator.Screen name="Filters" component={FiltersNavigator} />
      </NavigationContainer>
    );
  };

但最终返回错误 The action 'TOGGLE_DRAWER' was not handled by any navigator'

当我点击左侧的汉堡菜单按钮时,没有出现抽屉。

我在这里缺少什么?

注意:我使用的是 React Navigation 版本 5

更新:在此处粘贴我的完整代码:

import React from 'react';
import { NavigationContainer } from '@react-navigation/native';
import { createStackNavigator } from '@react-navigation/stack';
import { createDrawerNavigator } from '@react-navigation/drawer';
import { DrawerActions } from '@react-navigation/native';


import { Ionicons } from '@expo/vector-icons';

import { Platform } from 'react-native';
import { createMaterialBottomTabNavigator } from '@react-navigation/material-bottom-tabs';

import CategoriesScreen from '../screens/CategoriesScreen';
import CategoryMealsScreen from '../screens/CategoryMealsScreen';
import MealDetailScreen from '../screens/MealDetailScreen';

import FavoritesScreen from '../screens/FavoritesScreen';

import FiltersScreen from '../screens/FiltersScreen';

import HeaderButton from '../components/HeaderButton';
import { HeaderButtons, Item } from 'react-navigation-header-buttons';

import { createBottomTabNavigator } from '@react-navigation/bottom-tabs';

import { CATEGORIES, MEALS } from '../data/dummy-data';

import Colors from '../constants/colors';

const MealsNav = createStackNavigator();

const MealsNavigator = () => {
    return (
        <MealsNav.Navigator
            mode="modal"
            screenOptions={{
                headerStyle: {
                    backgroundColor: Colors.primaryColor,
                },
                headerTintColor: '#fff',
                headerTitleStyle: {
                    fontSize: 17
                }
            }}
        >
          <MealsNav.Screen
                name="Categories"
                component={CategoriesScreen}
                options={({ navigation, route }) => ({
                    title: 'Meals Categories',
                    headerLeft: () => (
                        <HeaderButtons HeaderButtonComponent={HeaderButton}>
                            <Item
                                title='Menu'
                                iconName='ios-menu'
                                onPress={() => {
                                    navigation.dispatch(DrawerActions.toggleDrawer());
                                }}
                            />
                        </HeaderButtons>
                    )
          })}
        />
            <MealsNav.Screen
                name="CategoryMeals"
                component={CategoryMealsScreen}
                options={({ route }) => {
                    const catId = route.params.categoryId;
                    const selectedCategory = CATEGORIES.find((cat) => cat.id === catId);

                    return {
                        title: selectedCategory.title,
                    };

                }}
            />
            <MealsNav.Screen
                name="MealDetail"
                component={MealDetailScreen}
                options={{
                    title: 'Meal Detail',
                    headerRight: () => (
                        <HeaderButtons HeaderButtonComponent={HeaderButton}>
                            <Item
                                title='Favorite'
                                iconName='ios-menu'
                                onPress={() => console.log('Mark as the favorite')}
                            />
                        </HeaderButtons>
                    ),
                }}
            />
        </MealsNav.Navigator>
    );
};

const MealsFavTabNavigator =
    Platform.OS === 'android'
        ? createMaterialBottomTabNavigator()
        : createBottomTabNavigator();

const getNavigationOptions = () => {
    if (Platform.OS === 'ios') {
        // Props for the ios navigator
        return {
            labeled: false,
            initialRouteName: 'Meals',
            tabBarOptions: {
                activeTintColor: 'tomato',
                inactiveTintColor: 'black',
            },
        };
    }
    // Props for android
    return {
        initialRouteName: 'Favorites',
        activeColor: 'tomato',
        inactiveColor: 'black',
        barStyle: { backgroundColor: Colors.primaryColor },
        shifting: true
    };
};

const MealsTabNav = () => {
    return (
        <NavigationContainer>
            <MealsFavTabNavigator.Navigator {...getNavigationOptions()} >
                <MealsFavTabNavigator.Screen
                    name="Meals"
                    component={MealsNavigator}
                    options={{
                        tabBarIcon: ({ focused, color, size }) => (
                            <Ionicons name="ios-restaurant" size={25} color={focused ? "tomato" : "black"} />
                        )
                    }}
                />
                <MealsFavTabNavigator.Screen
                    name="Favorites"
                    component={FavoritesNav}
                    options={{
                        tabBarIcon: ({ focused, color, size }) => (
                            <Ionicons name="ios-star" size={25} color={focused ? "tomato" : "black"} />
                        )
                    }}
                />
            </MealsFavTabNavigator.Navigator>
        </NavigationContainer>
    );
};

const FavoritesStack = createStackNavigator();

const FavoritesNav = () => {
    return (
        <FavoritesStack.Navigator
            screenOptions={{
                headerStyle: {
                    backgroundColor: Colors.primaryColor,
                },
                headerTintColor: '#fff',
                headerTitleStyle: {
                    fontSize: 17
                }
            }}>
            <FavoritesStack.Screen
                name="Favorites"
                component={FavoritesScreen}
            />
            <FavoritesStack.Screen
                name="MealDetail"
                component={MealDetailScreen}
                options={({ route }) => {
                    const mealId = route.params.mealId;
                    const selectedMeal = MEALS.find((meal) => meal.id === mealId);

                    return {
                        title: selectedMeal.title,
                    };
                }}
            />
        </FavoritesStack.Navigator>
    );
};



const FilterNav = createStackNavigator();

const FiltersNavigator = () => {
    return (
        <FilterNav.Navigator
            mode="modal"
            screenOptions={{
                headerStyle: {
                    backgroundColor: Colors.primaryColor,
                },
                headerTintColor: '#fff',
                headerTitleStyle: {
                    fontSize: 17
                }
            }}
        >
            <FilterNav.Screen
                name="Filters"
                component={FiltersScreen}
                options={{
                    title: 'Filters'
                }}

            />
        </FilterNav.Navigator>
    );
};


const mainNavigator = createDrawerNavigator();

const MainNavigatorDrawer = () => {
    return (
      <NavigationContainer>
      <mainNavigator.Navigator>
        <mainNavigator.Screen name="MealsFav" component={MealsFavTabNavigator} />
        <mainNavigator.Screen name="Filters" component={FiltersNavigator} />
      </mainNavigator.Navigator>
      </NavigationContainer>
    );
  };
  
export default MealsTabNav;

最佳答案

导航容器内应该有一个抽屉式导航器。

您只放置了屏幕。

const MainNavigatorDrawer = () => {
    return (
      <NavigationContainer>
      <mainNavigator.Navigator>
        <mainNavigator.Screen name="MealsFav" component={MealsFavTabNavigator} />
        <mainNavigator.Screen name="Filters" component={FiltersNavigator} />
      </mainNavigator.Navigator>
      </NavigationContainer>
    );
  };

关于reactjs - 世博会应用程序 : The action 'TOGGLE_DRAWER' was not handled by any navigator,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63169267/

相关文章:

javascript - onClick 不会呈现新的 react 组件。

javascript - 如何在 native react 中从此 map 对象中删除所有其他 id?

react-native - await 是 Expo XDE for React Native 中的保留字错误

android - Expo - 如何在 Android 平台上打开系统设置

react-native - 使用 Expo 的 React Native 上传图片在 iOS 上随机给出错误

javascript - npm start 上出现意外 token 错误的模块构建失败 - React/webpack

javascript - 通过删除不需要的查询参数同时保留其他参数来返回干净 URL 的最佳方法是什么?

javascript - React Native 混合风格 PropTypes

react-native - 应用程序退出后退单击android react native ?

javascript - 回顾我的代码 React 中的函数式编程