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)
| 归档时间: |
|
| 查看次数: |
3114 次 |
| 最近记录: |