Sign in

Build 10x products in minutes by chatting with AI - beyond just a prototype.
Managing data in React can be tricky, especially when you need to pass information through multiple levels of nested routes.
But what if there was an easier way to handle this?
With React Router v6, you can now use the useOutletContext hook to pass context data directly from a parent route to its child routes. Unlike the typical useContext hook, which requires you to set up context providers, useOutletContext simplifies this process by injecting data directly into the child components through the <Outlet> component. This makes routing and state management more straightforward, saving you time and effort when building your app.
Let's explore how this new feature works and how it can make your code cleaner and more efficient.
useOutletContext?The useOutletContext hook returns the context value from the closest parent <Outlet context={...} /> component. In practice, you define your shared data in a parent route, pass it as a prop via <Outlet context={...} />, and then access it in any child component using useOutletContext. This is particularly useful for dashboards, nested layouts, or any application that requires shared state across multiple routes.
Below is a simple demonstration:
1// ParentComponent.jsx 2import React, { useState } from "react"; 3import { Outlet } from "react-router-dom"; 4 5function ParentComponent() { 6 const [count, setCount] = useState(0); 7 8 return ( 9 <div> 10 <h1>Parent Component</h1> 11 {/* Passing the count state as context */} 12 <Outlet context={{ count, setCount }} /> 13 </div> 14 ); 15} 16 17export default ParentComponent;
1// ChildComponent.jsx 2import React from "react"; 3import { useOutletContext } from "react-router-dom"; 4 5function ChildComponent() { 6 const { count, setCount } = useOutletContext(); 7 8 const increment = () => setCount((c) => c + 1); 9 10 return ( 11 <div> 12 <h2>Child Component</h2> 13 <p>Count: {count}</p> 14 <button onClick={increment}>Increment</button> 15 </div> 16 ); 17} 18 19export default ChildComponent;
In this example, the parent route passes a state object to its <Outlet>, and the child component accesses it using useOutletContext.
The following Mermaid diagram illustrates the flow of data from the parent component to the child component via the Outlet context:
In this diagram:
<Outlet> which is provided with a context prop.useOutletContext to retrieve the data.This visual representation can help you understand how data flows through the component hierarchy.
useOutletContext<Outlet> component, it provides a seamless way to inject route-specific data.useOutletContext vs. useContextWhile both useOutletContext and useContext serve to share data, they differ in their use cases:
useContext: A general-purpose hook that requires you to create and provide a context using React’s createContext(). It works for any component that needs data.useOutletContext: Specifically designed for React Router. It allows a parent route to pass data to its immediate child routes via the <Outlet> component, which is ideal for nested routing scenarios.The useOutletContext hook in React Router v6 is a powerful tool for managing shared state across nested routes without the hassle of prop drilling. By integrating it with the <Outlet> component, you can build cleaner, more maintainable applications with ease. Whether you’re working on a complex dashboard or a multi-page app, useOutletContext can significantly streamline your data-sharing strategy.