React Navigation: useRoute hook example

Updated: January 7, 2023 By: A Goodman Post a comment

React Navigation provides a hook that helps you access the route object. It is the useRoute hook. This article will walk you through a complete example of using this hook in a React Native mobile app.

Note: To use hooks, we have to use functional components, not class-based components.

Example

The simple app we are going to build consists of 2 screens: HomeScreen and ProductScreen. The main content of each screen is just some text that presents the route name and the route key (this information is retrieved by using the useRoute hook).

App Preview

Here’s how it works:

The Code

Create a new React Native project, delete all the default code in App.js, and add this (don’t forget to install the required packages for React Navigation 6 – the latest version):

import React from "react";
import { View, Text, StyleSheet, Button } from "react-native";
import { NavigationContainer, useRoute } from "@react-navigation/native";
import { createNativeStackNavigator } from "@react-navigation/native-stack";

const MainStack = createNativeStackNavigator();

// This component displays the information about the current route
// It will be used in both HomeScreen and ProductScreen
const RouteInfo = (props) => {
  const route = useRoute();
  return (
    <View>
      <Text>Route Name: {route.name}</Text>
      <Text>Route Key: {route.key}</Text>
    </View>
  );
};

// Implement Home Screen
const HomeScreen = (props) => {
  return (
    <View style={styles.screen}>
      <RouteInfo />
      <Button
        onPress={() => props.navigation.navigate("Product")}
        title="Go To Product Screen"
      />
    </View>
  );
};

// Product Screen
const ProductScreen = (props) => {
  return (
    <View style={styles.screen}>
      <RouteInfo />
    </View>
  );
};

// Wire everything up in the App component
function App() {
  return (
    <NavigationContainer>
      <MainStack.Navigator>
        <MainStack.Screen name="Home" component={HomeScreen} />
        <MainStack.Screen name="Product" component={ProductScreen} />
      </MainStack.Navigator>
    </NavigationContainer>
  );
}

export default App;

/// Just some styles
const styles = StyleSheet.create({
  screen: {
    flex: 1,
    justifyContent: "center",
    alignItems: "center",
  },
});

Afterword

You’ve examined a basic but meaningful example about the useRoute hook of React Navigation. If you’d like to explore more new and interesting things about modern React Native and React, take a look at the following articles:

You can also check our React topic page and React Native topic page for the latest tutorials and examples.

Related Articles