Expo 应用程序:任何导航器均未处理“TOGGLE_DRAWER”操作

2024-04-14

我试图从 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>
    );
  };
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Expo 应用程序:任何导航器均未处理“TOGGLE_DRAWER”操作 的相关文章

随机推荐

  • SPRING4:无法读取候选组件类 CouchbaseConfig.class

    我有个问题 我正在使用 Spring4 我想添加一个配置以便能够使用 spring data couchbase 但我有一个错误 org springframework beans factory BeanDefinitionStoreEx
  • PackageBuilder.java 在 Drools 6.1.0.final 中不可用

    我是 drools 的新手 目前我们在项目中使用 Drools 5 4 0 目前我们使用Drools 5 4 0的RuleCompiler java和PackageBuilder java类来编译 xls文件并创建ruleSetObject
  • 如何在 iOS 中的 UIView 上应用模糊效果?

    在我的应用程序中 我想在 uiview 上应用模糊效果 那么我怎样才能实现模糊效果 我尝试通过下面的代码 UIGraphicsBeginImageContext scrollview bounds size scrollview layer
  • 检查 NSNumber 是否为空

    如何检查 NSNumber 对象是否为零或为空 好的 nil 很简单 NSNumber myNumber if myNumber nil doSomething 但是 如果对象已创建 但由于分配失败而没有任何值 我该如何检查呢 用这样的东西
  • OWIN 不记名令牌身份验证

    我有一些与不记名令牌相关的问题 在 欧文 您可以保护门票Protect ticket 像这样 ClaimsIdentity identity new ClaimsIdentity Startup OAuthServerOptions Aut
  • Rmarkdown 图像跳过文本

    我正在将 Rmarkdown PDF 文档与以下 YAML 设置放在一起 output pdf document fig caption true fig crop true toc depth 3 header includes usep
  • OpenCV - 如果从线程调用两次,imshow 就会挂起

    大家 我试图有一个单独的线程来显示和处理来自网络摄像头的图像 这些操作不能在主线程中 因为它专用于其他任务 我需要做的是停止并最终重新启动线程 发生的情况是 线程第一次运行 但在第二次运行时 imshow 调用永远冻结 我用一个偏离另一个S
  • 如何在工作区中的两个xcode项目之间共享文件?

    我了解了 Xcode 工作区 我知道如何共享静态库 但我想在工作区中的两个 Xcode 项目之间共享文件 是否可以一次运行多个目标 您能给我提供如何执行此操作的信息吗 提前致谢 即使项目位于同一级别 没有子项目 在同一工作区中的项目之间共享
  • 为什么只有第二个数组维度很重要?

    为什么在处理二维数组时只有第二维对编译器很重要 我就是无法理解这一点 谢谢 因为编译器需要弄清楚如何从内存中访问数据 第一个维度并不重要 因为当给定所有其他大小时 编译器可以计算项目的数量 例子 int a1 1 2 3 4 编译器知道为
  • SAS:如何计算除某些字符变量之外的所有字符变量的频率

    我知道我可以使用类似以下内容来计算所有字符的频率 proc freq data sashelp class tables char run 但是 有没有办法排除一些变量呢 我想做类似的事情 proc freq data sashelp cl
  • Ivy 通过 Nexus 代理

    有谁知道我如何在 Ivy 中指定 Maven 中的镜像 mirrorOf 之类的东西 我正在使用本地 Maven 代理 Nexus 并且需要该工具来指定 Nexus 代理应访问哪个父存储库 在 Maven 中我简单地做
  • 手势方法(平移手势和滑动手势)之间是否有优先级条件?

    我正在开发一个应用程序 其中使用了平移手势和滑动手势 因此 每次我执行 滑动手势 时 但总是会调用 平移手势 中的方法 而不会调用 滑动手势 方法 所有手势方法之间有优先级吗 您可以通过实现以下方法来并行调用它们UIGestureRecog
  • 如何在 android studio 中安装自定义库? [复制]

    这个问题在这里已经有答案了 我想做的是参考这个双向网格视图库 https github com jess anders two way gridview并在我的项目中使用该控件而不是标准的 gridview 它似乎没有以任何方式编译 你可以
  • 将 json 请求 POST 到 Solr,请求中带有cursorMark

    是否可以包括cursorMarkPOST 请求正文中的值而不是将其作为查询字符串参数发送 以下查询 query val abc limit 10 cursorMark sort id asc 返回一条错误消息 JSON 请求中未知的顶级键
  • Oracle设置默认NLS_LANG

    我在 RHEL6 上运行 Oracle 数据库 11g 如果没有客户端NLS LANG 则设置某些utf8字符的长度为2 设置NLS LANG AMERICAN AMERICA UTF8后 长度仅为1 如何更改整个数据库的默认 NLG LA
  • 静态变量的线程安全初始化

    我一直在使用这种模式来初始化类中的静态数据 对我来说 它看起来是线程安全的 但我知道线程问题有多么微妙 这是代码 public class MyClass bad code do not use static string myResour
  • Jasmine:测试 setTimeout 函数抛出错误

    我想测试一个方法的错误处理 该方法使用 setTimeout 安排工作 该错误将在预定部分抛出 即 function sutWithSetTimeout setTimeout function throw new Error pang 1
  • `scipy.ndimage.zoom` 与 `order=0` 的 `skimage.transform.rescale`

    我正在创建一个彩色灰度图像来显示图像块的分类 我需要使用零阶对低分辨率分类图像进行上采样以匹配原始图像大小 When I use skimage transform rescale I 16 order 0 I get the desire
  • Vue.js $children 按组件名称

    我正在尝试按名字访问特定的孩子 目前 由于孩子所在的位置 我这样称呼孩子 this root children 0 没关系 只要那个孩子总是 0 但如果有一种方法可以做类似的事情那就太好了 this root children detail
  • Expo 应用程序:任何导航器均未处理“TOGGLE_DRAWER”操作

    我试图从 MealsNavigator 导航中显示一个抽屉 到目前为止 我导入了 ff 必需品 import React from react import NavigationContainer from react navigation