bugl
bugl
HomeLearnPatternsPathsSearch
HomeLearnPatternsPathsSearch

Loading lesson path

Learn/React/Hooks and State Management
React•Hooks and State Management

React useContext Hook

Flash cards

Review the key moves

1/4
Core idea

What is the main idea behind React useContext Hook?

Lesson checks

Practice each idea before moving on

Short Mimo-style checks built from this lesson's code, terms, and sequence.

1Quick choice

Which statement best captures the main point of this lesson?

2Fill blank

Complete the missing token from the example code.

___ { useState } from 'react';
3Order

Put the learning moves in the order that makes the concept easiest to apply.

It can be used together with the useState Hook to share state between deeply nested components more easily than with useState alone.
React Context is a way to manage state globally.
Use the useContext Hook

React Context

React Context is a way to manage state globally.

It can be used together with the useState Hook to share state between deeply nested components more easily than with useState alone.

The Problem

State should be held by the highest parent component in the stack that requires access to the state.

To illustrate, we have many nested components. The component at the top and bottom of the stack need access to the state.

To do this without Context, we will need to pass the state as "props" through each nested component. This is called "prop drilling".

Example

Passing "props" through nested components:

import { useState } from 'react';
import { createRoot } from 'react-dom/client';
function Component1() {
 const [user, setUser] = useState("Linus");
 return ( <> <h1>{`Hello ${user}!`}</h1> <Component2 user={user} /> </> );
}
function Component2({ user }) {
 return ( <> <h1>Component 2</h1> <Component3 user={user} /> </> );
}
function Component3({ user }) {
 return ( <> <h1>Component 3</h1> <h2>{`Hello ${user} again!`}</h2> </> );
}
createRoot(document.getElementById('root')).render( <Component1 /> );

Even though component 2 did not need the state, it had to pass the state along so that it could reach component 3.

The Solution

The solution is to create context.

Create Context

To create context, you must Import createContext and initialize it:

import { useState, createContext, useContext } from 'react';
import { createRoot } from 'react-dom/client';
const UserContext = createContext();

Context Provider

Wrap child components in the Context Provider and supply the state value.

function Component1() {
 const [user, setUser] = useState("Linus");
 return ( <UserContext.Provider value={user}> <h1>{`Hello ${user}!`}</h1> <Component2 /> </UserContext.Provider> );
}

Now, all components in this tree will have access to the user Context.

Use the useContext Hook

In order to use the Context in a child component, we need to access it using the useContext Hook.

First, include the useContext in the import statement:

import { useState, createContext, useContext } from "react";

Then you can access the user Context in all components:

function Component3() {
 const user = useContext(UserContext);
 return ( <> <h1>Component 3</h1> <h2>{`Hello ${user} again!`}</h2> </> );
}

Full Example

Example

Here is the full example using React Context:

import { useState, createContext, useContext } from 'react';
import { createRoot } from 'react-dom/client';
const UserContext = createContext();
function Component1() {
 const [user, setUser] = useState("Linus");
 return ( <UserContext.Provider value={user}> <h1>{`Hello ${user}!`}</h1> <Component2 /> </UserContext.Provider> );
}
function Component2() {
 return ( <> <h1>Component 2</h1> <Component3 /> </> );
}
function Component3() {
 const user = useContext(UserContext);
 return ( <> <h1>Component 3</h1> <h2>{`Hello ${user} again!`}</h2> </> );
}
createRoot(document.getElementById('root')).render( <Component1 /> );

Previous

React useEffect Hooks

Next

React useRef Hook