反应导航:在多个标签导航中使用单个屏幕组件

时间:2020-05-06 18:21:43

标签: javascript reactjs react-native react-navigation react-navigation-v5

我正在使用createMaterialTopTabNavigator创建带有两个不同标签的顶部标签导航。

每个选项卡显示一个图像-汽车或卡车。

我想做的是使用单个屏幕组件而不是两个组件屏幕(我现在有)。显示的选项卡屏幕的图片根据活动的选项卡而变化。

在反应导航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 个答案:

答案 0 :(得分:1)

您可以使用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' }}
/>