React Navigation 6 隐藏抽屉项目

Joe*_*ugh 19 reactjs react-navigation react-navigation-drawer

如何隐藏屏幕,使其不显示为 @react-navigation/drawer 版本 6 抽屉中的项目。

在 React Navigation 5 中,它是通过创建像这样的自定义抽屉内容来实现的

const CustomDrawerContent = (props: DrawerContentComponentProps) => {
  const { state, ...rest } = props;
  const includeNames = ["ScreenOne", "ScreenTwo"];
  const newState = { ...state }; //copy from state before applying any filter. do not change original state
  newState.routes = newState.routes.filter(
    (item) => includeNames.indexOf(item.name) !== -1
  );
  return (
    <DrawerContentScrollView {...props}>
      <DrawerItemList state={newState} {...rest} />
    </DrawerContentScrollView>
  );
};
Run Code Online (Sandbox Code Playgroud)

正如另一个答案中所述。TypeError: Cannot read property 'key' of undefined我刚刚升级到react-navigation 6,使用这种技术,当我尝试导航这些隐藏屏幕之一时,我收到错误。谁能帮我吗?

更新 - 找到解决方案

我自己找到了一个解决方案,因此将其放在这里供其他人查找。设置抽屉项目样式显示隐藏,如下所示:

<DrawerStack.Screen
   name="ScreenName"
   component={ScreenComponent}
   options={{
     drawerItemStyle: {
       display: "none",
     },
   }}
/>
Run Code Online (Sandbox Code Playgroud)

小智 0

您必须传递headerLeft: false到 Drawer.Screen

    <Drawer.Navigator>
      <Drawer.Screen
        name="Home"
        options={{title: '', headerTransparent: true, headerLeft: false}}>
        {props => <Home {...props} />}
      </Drawer.Screen>
    </Drawer.Navigator>
Run Code Online (Sandbox Code Playgroud)