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