我已经写了this document这样的类型定义,但是当我使用嵌套导航时会出现问题。
以下是示例代码:
在我的App.tsx
export type MainStackParamList = {
Setting: undefined
}
export type TabParamList = {
Home: undefined
Personal: undefined
}
const MainStack = createNativeStackNavigator<MainStackParamList>()
const Tab = createBottomTabNavigator<TabParamList>()
const RootStack = createNativeStackNavigator()
const MainStackScreen = () => (
<MainStack.Navigator screenOptions={{ headerShown: false }}>
<MainStack.Screen name="Setting" component={Setting} />
</MainStack.Navigator>
)
const TabScreen = () => (
<Tab.Navigator screenOptions={{ headerShown: false }}>
<Tab.Screen name="Home" component={Setting} />
<Tab.Screen name="Personal" component={Setting} />
</Tab.Navigator>
)
const RootStackScreen = () => (
<RootStack.Navigator screenOptions={{ headerShown: false }}>
<RootStack.Screen name="Tab" component={TabScreen} />
<RootStack.Screen name="Main" component={MainScreen} />
</RootStack.Navigator>
)
在Home.tsx
type HomeRouteProp = RouteProp<TabParamList, 'Home'>
type HomeNavigationProp = CompositeNavigationProp<
BottomTabNavigationProp<TabParamList, 'Home'>,
NativeStackNavigationProp<MainStackParamList>
>
type Props = {
route: HomeRouteProp
navigation: HomeNavigationProp
}
// ...
navigation.navigate('Main', { screen: 'Setting' })
和打字稿说不能将'Main'分配给'Home'| “个人” | “设置”
答案 0 :(得分:2)
您还需要为根堆栈添加类型。
type RootStackParamList = {
Tab: undefined;
Main: undefined;
}
然后为您的导航道具:
// Navigation prop for your MainStack
type MainNavigationProp = CompositeNavigationProp<
NativeStackNavigationProp<MainStackParamList, 'Setting'>,
NativeStackNavigationProp<RootStackParamList>
>
// Navigation prop for your Home
type HomeNavigationProp = CompositeNavigationProp<
BottomTabNavigationProp<TabParamList, 'Home'>,
MainNavigationProp
>
使用CompositeNavigationProp
组合导航道具取决于嵌套。在这里,您的Home
屏幕嵌套在MainStack
内部,因此其导航道具需要与MainStack
的导航道具结合使用。
上一个答案:
在堆栈中,您有Setting
,在选项卡中,您有Home
和Personal
。 Main
的任何地方都没有定义,因此错误是正确的。
好像您的Main
是您的MainStack
,我想您是在标签页中显示的?然后,您需要在Main: undefined
TabParamList