Context

Share global data without passing through props, does make components less reusable

this.context will return the nearest ancestor's value of that context type, so can specialize further down tree

For multiple contexts, just add multiple providers and contexts if needed

Usage

1) Create context(seperate file? theme-context.js)

PizzaContext.js

import React from "react";

const ThemeContext = React.createContext('light'); //default value

export default ThemeContext;

2) Add Provider

function App(){
  return (
    <ThemeContext.Provider value="dark"> //overrides default
    <Toolbar />
    </ThemeContext.Provider>
  );
}

3) Now anything in subtree of Provider can access data

  • useContext hook can access data

  • Contexttypes can access data in classes

Advanced

Updating Context and Consumers Example

Pass a ft with the context that lets you toggle it

theme-context.js

theme-toggler-button.js

app.js

Last updated