не удается получить доступ к реквизитам в react navigation

#react-native #react-navigation

#react-native #react-навигация

Вопрос:

Я разработал заголовок поверх навигатора вкладок со значком, который приведет меня к экрану. Но я получаю сообщение об ошибке при нажатии и не могу получить доступ к реквизитам и получаю сообщение об ошибке с указанием undefined is not an object(evaluating '_this.props.navigation')

Я уже пытался передать навигационный реквизит, а также пытался использовать withNavigation of react navigation

 

const SessionTabNavigator= createMaterialTopTabNavigator(
  {
    AllSessionList: { 
      screen: AllSessionListScreen,
      navigationOptions: {
        tabBarLabel: ({ tintColor,focused }) =>
            <Text style={{color: tintColor, fontSize: 12, fontFamily: Platform.OS == 'ios' ? "Krub" : "Krub SemiBold", 
              fontWeight:Platform.OS == 'ios' ? "bold" : "normal", fontStyle: Platform.OS == 'ios' ? "normal" : "normal"}}>All Session List</Text>
        } 
    },
    MySessionList: { 
      screen: MySessionListScreen,
      navigationOptions: {
        tabBarLabel: ({ tintColor,focused }) =>
            <Text style={{color: tintColor, fontSize: 12, fontFamily: Platform.OS == 'ios' ? "Krub" : "Krub SemiBold", 
              fontWeight:Platform.OS == 'ios' ? "bold" : "normal", fontStyle: Platform.OS == 'ios' ? "normal" : "normal"}}>My Session List</Text>
        }
      },
  },
  {
    headerMode: "none",
    navigationOptions: {
      headerVisible: false
    },
    tabBarComponent: TabBarBottom,
    tabBarPosition: 'top',

    tabBarOptions: {
      style: { elevation: 0,shadowColor: 'transparent',backgroundColor: '#E8E8E8' },
      showIcon: false,
      tabStyle: {

      height: 60,
      paddingVertical: 8,
      },
      iconStyle: {
        flexGrow: 0,
      marginBottom: 0,
      marginTop: 0
       },
       labelStyle: { justifyContent: 'center', alignItems: 'center',fontSize: 12 },
      indicatorStyle: { height: null, top: 0, backgroundColor: '#E8E8E8' },
      activeTintColor: '#cc0000',
      inactiveTintColor: '#808080',
    },
    lazy: true,
    animationEnabled: false,
    swipeEnabled: false,
  },
  {

    // initialRouteName:  'MySessionList',
  }

);


const sessionNavigator = createStackNavigator(
  {
    SessionHome: {
      screen: SessionTabNavigator,

      navigationOptions: {

      title: 'Session',
      headerStyle: {
        backgroundColor: '#cc0000'
      },
      headerRight: (
      <TouchableOpacity activeOpacity={0.8} onPress={()=>this.props.navigation.navigate('Notification')}style={{ marginHorizontal:15}}>
        <Icon family= 'Ionicons' name='ios-notifications'  size={25} color= "#FFFFFF"   />
      </TouchableOpacity>
    ),
      headerLeft: (
      <View style={{ marginHorizontal:15}}>
      </View>
    ),

      headerTintColor: '#FFFFFF',
      headerTitleStyle: {
        fontSize:25,
        fontFamily: Platform.OS == 'ios' ? "Sansation" : "Sansation Bold", 
        fontWeight:Platform.OS == 'ios' ? "bold" : "normal",
        flex: 1,
        alignSelf: 'center',
        textAlign: 'center',
       backgroundColor:'transparent',
      },
    },

    },



  },

);

sessionNavigator.navigationOptions = ({ navigation }) => {
  let tabBarVisible = true;
  if (navigation.state.index > 0) {
    tabBarVisible = false;
  }

  return {
    tabBarVisible,
  };
};




const Tabscreen = createMaterialTopTabNavigator(
  {
    Session: {
      screen: sessionNavigator,
      navigationOptions: {
        tabBarIcon: ({ focused,tintColor }) =>
          focused ? (
            <Icon name="slideshare" family = 'FontAwesome' size={24} color={tintColor} />
          ) : (
            <View style={{justifyContent: 'center', alignItems: 'center'}}>
            <Icon name="slideshare" family = 'FontAwesome' size={26} color={tintColor} />
            </View>
          ),
          tabBarLabel: ({ tintColor,focused }) =>
          focused  ? (
            <Text style={{color: tintColor, fontSize: 10, fontFamily: Platform.OS == 'ios' ? "Krub" : "Krub Medium Italic", 
              fontWeight:Platform.OS == 'ios' ? "bold" : "normal", fontStyle: Platform.OS == 'ios' ? "italic" : "normal"}}>Session</Text>
          ) : null
          ,
      }
    },
    Chat: {
      screen: chatNavigator,
      navigationOptions: {
        tabBarIcon: ({ focused,tintColor }) =>
          focused ? (
            <Icon name="chat" family = 'Entypo' size={24} color={tintColor} />
          ) : (
          <View style={{justifyContent: 'center', alignItems: 'center'}}>
            <Icon name="chat" family = 'Entypo' size={26} color={tintColor} />
            </View>
          ),
          tabBarLabel: ({ tintColor,focused }) =>
          focused  ? (
            <Text style={{color: tintColor, fontSize: 10, fontFamily: Platform.OS == 'ios' ? "Krub" : "Krub Medium Italic", 
              fontWeight:Platform.OS == 'ios' ? "bold" : "normal", fontStyle: Platform.OS == 'ios' ? "italic" : "normal"}}>Chat</Text>
          ) : null
          ,
      }
    },
    Profile: {
      screen: profileNavigator,
      navigationOptions: {
        tabBarIcon: ({ focused,tintColor }) =>
          focused ? (
            <Icon name="person" size={24} color={tintColor} />
          ) : (
            <View style={{justifyContent: 'center', alignItems: 'center'}}>
            <Icon name="person" size={26} color={tintColor} />
            </View>
          ),
          tabBarLabel: ({ tintColor,focused }) =>
          focused  ? (
            <Text style={{color: tintColor, fontSize: 10, fontFamily: Platform.OS == 'ios' ? "Krub" : "Krub Medium Italic", 
              fontWeight:Platform.OS == 'ios' ? "bold" : "normal", fontStyle: Platform.OS == 'ios' ? "italic" : "normal"}}>Profile</Text>
          ) : null
          ,
      }
    }
  },
  {
    // lazy: true


    initialRouteName: "Session",
    tabBarComponent: TabBarTop,
    tabBarPosition: "bottom",
    tabBarOptions: {
      style: {
        backgroundColor: "#808080"
      },
      upperCaseLabel: false,
      labelStyle: {
        margin:0
      },
      showLabel: true,
      showIcon: true,
      tabStyle: {
        height: 60
      },
      iconStyle: {
        flexGrow: 0,
        marginBottom: 5
      },
      indicatorStyle: {
        backgroundColor: "#cc0000",
        height: null,
        top: 0
      },
      activeTintColor: "#FFFFFF",
      inactiveTintColor: "#D9D9D9"
    },
    animationEnabled: true,
    swipeEnabled: false
  }
);

const AppNavigator = createSwitchNavigator(
  {

     LoginCheck: {
      screen: LoginCheckScreen
    },

     Notification: {
      screen: NotificationScreen
    },

    Signup: {
      screen: SignupScreen
    },

    Login: {
      screen: LoginScreen
    },
    Tabscreen: {
      screen: Tabscreen
    }
  },
  {
    initialRouteName: "LoginCheck",
    headerMode: "none",
    navigationOptions: {
      headerVisible: false
    }
  }
);


export default createAppContainer(AppNavigator)
 

ActualResult: получение ошибки с указанием undefined is not an object(evaluating '_this.props.navigation')

Ожидаемый результат: перейдите к экрану уведомлений

Ответ №1:

Вам просто нужно передать prop в конфигурацию экрана,

 navigationOptions: prop => ({ // prop is passed here
      title: 'Session',
      headerStyle: {
      ...
      headerRight: ( // below line use prop.navigation instead of this.props.navigation
      <TouchableOpacity activeOpacity={0.8} onPress={()=>prop.navigation.navigate('Notification')}style={{ marginHorizontal:15}}>
        <Icon family= 'Ionicons' name='ios-notifications'  size={25} color= "#FFFFFF"   />
      </TouchableOpacity>
    ),
 

Комментарии:

1. Спасибо @Jaydeep Кажется, я пробовал этот метод, но во время навигации допустил опечатку. В любом случае спасибо