Creating a complex strongly-typed context for function components
In this lesson, we'll learn how to implement a strongly-typed context where consumers can change values within it.
Explicitly setting the context type #
In this lesson, we are going to enhance the context from the last lesson so that the theme can be updated by consumers.
In the last lesson, the type for the context was inferred from the default value, which was a simple string
. The type for our enhanced context is going to be a little more complex:
type ThemeContextType = {
theme: string;
setTheme: (value: string) => void;
};
So, there will be a theme
property containing the current value for the theme and a setTheme
method to update the current theme.
React’s createContext
function expects us to supply a parameter for initial context value. We can supply a default value for the theme
property, but it doesn’t make sense to provide a default implementation for the setTheme
method. So, a simple approach is to pass in undefined
as the initial value:
const ThemeContext = React.createContext(undefined);
What do you think is the inferred type for the context value in this case?
Get hands-on with 1300+ tech skills courses.