React Navigation: использование одноэкранного компонента в навигации по нескольким вкладкам - PullRequest
0 голосов
/ 06 мая 2020

Я использую createMaterialTopTabNavigator для создания верхней навигации по вкладкам с двумя разными вкладками.

На каждой вкладке отображается одно изображение - автомобиль или грузовик.

Что я хочу сделать используется одноэкранный компонент, а не двухкомпонентный экран (который у меня есть прямо сейчас). Изображение отображаемой вкладки изменяется в зависимости от активной вкладки.

Возможно ли это в React-Navigation 5.

Это то, что у меня есть:

import * as React from 'react';
import { Text, View } from 'react-native';
import { NavigationContainer } from '@react-navigation/native';
import { createMaterialTopTabNavigator } from '@react-navigation/material-top-tabs';

function CarScreen() {
  return (
    <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}>
      <Text>Image of car</Text>
    </View>
  );
}

function TruckScreen() {
  return (
    <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}>
      <Text>Image of truck</Text>
    </View>
  );
}


const Tab = createMaterialTopTabNavigator();

function MyTabs() {
  return (
    <Tab.Navigator
      initialRouteName="Car"
    >
      <Tab.Screen
        name="Car"
        component={FeedScreen}
        options={{ tabBarLabel: 'Car' }}
      />
      <Tab.Screen
        name="Truck"
        component={NotificationsScreen}
        options={{ tabBarLabel: 'Truck' }}
      />
    </Tab.Navigator>
  );
}
export default function App() {
  return (
    <NavigationContainer>
      <MyTabs />
    </NavigationContainer>
  );
}

1 Ответ

1 голос
/ 07 мая 2020

Вы можете получить доступ к имени маршрута, используя props.route.name, и вы можете изменить изображение, используя это условие.

Я также сделал здесь закуску: https://snack.expo.io/@gie3d / shallow-blueberries


function CarOrTruck({route}) {
  const getImageUrl = (routeName) => {
    if (routeName === 'Car') {
      return 'https://www.extremetech.com/wp-content/uploads/2019/12/SONATA-hero-option1-764A5360-edit.jpg'
    } else if (routeName === 'Truck') {
      return 'https://www.volvotrucks.com/content/dam/volvo/volvo-trucks/masters/press-releases/2020/feb/pr-2952-fh/high-res-08A3977-FH-4x2-semi-trailer-long-haul-on-road.jpg';
    } else {
      return 'https://brayve.net/wp-content/uploads/2019/06/4004/the-secret-history-of-the-google-logo.jpg-23keepProtocol'
    }
  }

  const imageUrl = getImageUrl(route.name);
  return (
    <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}>
      <Image source={{uri: imageUrl}} style={{width: 200, height: 100, resizeMode: 'contain'}} />
    </View>
  );
}

Итак, в вашем 2 это относится к component = {CarOrTruck}

 <Tab.Screen
    name="Car"
    component={CarOrTruck}
    options={{ tabBarLabel: 'Car' }}
/>
<Tab.Screen
    name="Truck"
    component={CarOrTruck}
    options={{ tabBarLabel: 'Truck' }}
/>
...