initialRouteName= "NAME"
- это ключевое слово, чтобы убедиться, что у вас есть значение по умолчанию и вы используете navigate()
push()
pop()
соответственно.
Во-первых, создайте пользовательский TabBar, чтобы мы могли писать собственные функции, выполняемые с помощью onPress
function MyTabBar({ state, descriptors, navigation }) {
return (
<View style={{ flexDirection: 'row' }}>
{state.routes.map((route, index) => {
const { options } = descriptors[route.key];
const label =
options.tabBarLabel !== undefined
? options.tabBarLabel
: options.title !== undefined
? options.title
: route.name;
const isFocused = state.index === index;
const onPress = () => {
navigation.reset({
index: 0,
routes: [{ name: 'Screen1' }],
})
if (!isFocused && !event.defaultPrevented) {
navigation.navigate(route.name);
}
}}
const onLongPress = () => {
navigation.emit({
type: 'tabLongPress',
target: route.key,
});
};
Затем в TabScreens
переписать исходный TabBar
в Tab.Navigator
с помощью tabBar=...
затем звоните navigation.reset()
с index:0
и routes:{{name: 'Screen1'}}
каждый раз, когда нажимается MyTabBar
.
const TabScreens = ()=>{
return(
<Tab.Navigator tabBar={props => <MyTabBar {...props} />} initialRouteName="Tab1Screens" >
<Tab.Screen
name = "Tab1Screens"
component = {Tab1Screens}
/>
<Tab.Screen
name = "Tab2Screens"
component = {Tab2Screens}
/>
</Tab.Navigator>
)
}
return (
<TouchableOpacity
accessibilityRole="button"
accessibilityStates={isFocused ? ['selected'] : []}
accessibilityLabel={options.tabBarAccessibilityLabel}
testID={options.tabBarTestID}
onPress={onPress}
onLongPress={onLongPress}
style={{ flex: 1 }}
>
<Text style={{ color: isFocused ? '#673ab7' : '#222' }}>
{label}
</Text>
</TouchableOpacity>
);
})}
</View>
);
}
Это может быть значительно улучшено, например:
-some logic before `navigation.reset()`
-Accessing onPress without creating a new component
-etc..
наконец, закуска доступна здесь: https://snack.expo.io/@karammarrie / customtabbar