React native - Как переходить на несколько экранов стека навигатора?
Я занимаюсь разработкой приложения, которое имеет экраны на нескольких уровнях, где на 3-м уровне мне требуется переходить на три разных экрана в разных условиях.
подобно
OrderDetail
-> EventDetail
-> ScoreDetail
-> UserDetail
-> CreditCard
-> Success
И стек такой
const ScoreStack = createStackNavigator({
ScoreCategory: {
screen: Screen2,
navigationOptions: ({ navigation }) => {
return {
// headerTitle: 'Food Category',
headerLeft: (
<MaterialIcons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="menu"
size={30} color="#ffffff"
/>
),
headerRight: (
<Icons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="dots-vertical"
size={30} color="#ffffff"
/>
),
headerTintColor: "#ffffff",
headerStyle: {
backgroundColor: "#FF0000"
}
};
}
},
DetailScoreScreen: {
screen: Screen7,
navigationOptions: ({ navigation }) => {
return {
// headerTitle: 'Food Category',
headerRight: (
<Icons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="dots-vertical"
size={30} color="#ffffff"
/>
),
headerTintColor: "#ffffff",
headerStyle: {
backgroundColor: "#FF0000"
}
};
}
}
},
{
defaultNavigationOptions: {
gesturesEnabled: false
}
});
const EventsStack = createStackNavigator({
EventCategory: {
screen: Screen2,
navigationOptions: ({ navigation }) => {
return {
// headerTitle: 'Food Category',
headerLeft: (
<MaterialIcons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="menu"
size={30} color="#ffffff"
/>
),
headerRight: (
<Icons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="dots-vertical"
size={30} color="#ffffff"
/>
),
headerTintColor: "#ffffff",
headerStyle: {
backgroundColor: "#FF0000"
}
};
}
},
DetailEventsScreen: {
screen: Screen8,
navigationOptions: ({ navigation }) => {
return {
// headerTitle: 'Food Category',
headerRight: (
<Icons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="dots-vertical"
size={30} color="#ffffff"
/>
),
headerTintColor: "#ffffff",
headerStyle: {
backgroundColor: "#FF0000"
}
};
}
}
},
{
defaultNavigationOptions: {
gesturesEnabled: false
}
});//
const SuccessScreenStack = createStackNavigator({
FoodSize: {
screen: Screen3,
navigationOptions: ({ navigation }) => {
return {
// headerTitle: 'Food Category',
header: null,
headerLeft: (
<MaterialIcons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="menu"
size={30}
/>
)
};
}
},
FinishDetail: {
screen: Screen1,
navigationOptions: ({ navigation }) => {
return {
// headerTitle: 'Food Category',
header: null,
headerRight: (
<Icons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="dots-vertical"
size={30} color="#ffffff"
/>
),
headerTintColor: "#ffffff",
headerStyle: {
backgroundColor: "#FF0000"
}
};
}
}
},
{
defaultNavigationOptions: {
gesturesEnabled: false
}
});
const CreditCardScreenStack = createStackNavigator({
FoodSize: {
screen: CreditCardScreen,
navigationOptions: ({ navigation }) => {
return {
// headerTitle: 'Food Category',
header: null,
headerLeft: (
<MaterialIcons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="menu"
size={30}
/>
)
};
}
},
OrderSuccessDetail: {
screen: SuccessScreenStack,
navigationOptions: ({ navigation }) => {
return {
// headerTitle: 'Food Category',
header: null,
headerRight: (
<Icons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="dots-vertical"
size={30} color="#ffffff"
/>
),
headerTintColor: "#ffffff",
headerStyle: {
backgroundColor: "#FF0000"
}
};
}
}
},
{
defaultNavigationOptions: {
gesturesEnabled: false
}
});
const UserDetailStack = createStackNavigator({
FoodSize: {
screen: Screen2,
navigationOptions: ({ navigation }) => {
return {
// headerTitle: 'Food Category',
header: null,
headerLeft: (
<MaterialIcons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="menu"
size={30}
/>
)
};
}
},
CreditCardDetail: {
screen: CreditCardScreenStack,
navigationOptions: ({ navigation }) => {
return {
// headerTitle: 'Food Category',
header: null,
headerRight: (
<Icons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="dots-vertical"
size={30} color="#ffffff"
/>
),
headerTintColor: "#ffffff",
headerStyle: {
backgroundColor: "#FF0000"
}
};
}
}
},
{
defaultNavigationOptions: {
gesturesEnabled: false
}
});
const OrderDetailStack = createStackNavigator({
FoodSize: {
screen: Screen6,
navigationOptions: ({ navigation }) => {
return {
// headerTitle: 'Food Category',
header: null,
headerLeft: (
<MaterialIcons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="menu"
size={30}
/>
)
};
}
},
UserDetail: {
screen: UserDetailStack,
navigationOptions: ({ navigation }) => {
return {
// headerTitle: 'Food Category',
header: null,
headerRight: (
<Icons
onPress={() => navigation.openDrawer()}
style={{ paddingLeft: 10 }}
name="dots-vertical"
size={30} color="#ffffff"
/>
),
headerTintColor: "#ffffff",
headerStyle: {
backgroundColor: "#FF0000"
}
};
}
}
},
{
defaultNavigationOptions: {
gesturesEnabled: false
}
});
На экране OrderDetail мне нужно идти тремя путями в зависимости от условий
Перейдите к действию, как это.
actionOnRow = (item) => {
this.props.navigation.navigate('UserDetail')
}
Пожалуйста, объясните мне, как создать стек для поддержки этой структуры / уровня экранов. Как будто я пишу this.props.navigation.navigate('UserDetail')
Как мне сделать, чтобы открыть любой из этих трех экранов после него.