React Context

Learn how to create and use React context.

A React application consists of components that can receive props passed from the parent. As we know, props flow from the parent component down to a child component. React context can be used to save a state value and make it available and accessible to all components without passing it down as props. React context creates a general location where data can be placed and retrieved.

Creating a context

Open the context.js file. On line 3, a context is created by using React.createContext. On line 5, a function named AppProvider is defined. Inside this function on line 6, we declare a state variable called data and a setData function that will change the data state variable. The created context stores a string value and a function to change that value.

An AppContext.Provider component is returned from the AppProvider function, which is wrapped with the children prop. The children prop is a general reference to all components that are placed inside of a parent component. The AppContext.Provider has a value prop to which we pass data and setData. The AppContext.Provider` is returned on line 8.

The <DisplayName/> component is a child of the parent, <App/>. So, the children prop is any component placed inside of a parent.

To use the data stored in the context, we define a function (hook) called useData. This hook extracts the data and the function used for changing the data from the context. On line 16, we pass the AppContext that we created defined on line 3 to React.useContext. On line 17, an if check is performed to determine if we have an AppContext. The AppContext is returned from the function on line 20, or we throw an error if context isn’t found. An object is exported from the file on line 23 that contains an AppProvider component and the useData hook.

Using React context

To use the created React context, the components that consume the context are wrapped in a Context.Provider. Remember the context.js file in which we exported the AppProvider? The AppProvider is used to wrap the App component. The AppProvider becomes the parent of the application.

On line 6 of the index.js file, AppProvider is imported from the context.js. The AppProvider is used to wrap the App component, making it the parent component. Any component that needs access to the stored context can import the useData hook. On line 2 of the viewDataComponent.js file, the useData hook is imported. The useData hook returns the data and setData functions saved in context. We only need the data here, so we extract it on line 5. The data is displayed in the component on line 7.

The setDataComponent.js file is a component used to set the value of the data inside the context. The setData function is destructured from the useData hook. The input textbox has an event handler attached to its onChange event called handleChange. The value of the textbox is passed to the setData function to change it. This causes the component to rerender.

Get hands-on with 1300+ tech skills courses.