using-context-api
Context API Patterns in React 19
Basic Pattern
import { createContext, use, useState } from 'react';
const UserContext = createContext(null);
export function UserProvider({ children }) {
const [user, setUser] = useState(null);
return (
<UserContext value={{ user, setUser }}>
{children}
</UserContext>
);
}
export function useUser() {
const context = use(UserContext);
if (!context) {
throw new Error('useUser must be used within UserProvider');
}
return context;
}
React 19: Conditional Context Access
use() allows context access inside conditionals (unlike useContext):
function Component({ isPremium }) {
let theme;
if (isPremium) {
theme = use(ThemeContext);
}
return <div className={theme}>Content</div>;
}
Splitting Contexts
Avoid unnecessary re-renders by splitting contexts:
const UserContext = createContext(null);
const ThemeContext = createContext('light');
function App() {
const [user, setUser] = useState(null);
const [theme, setTheme] = useState('light');
return (
<UserContext value={{ user, setUser }}>
<ThemeContext value={{ theme, setTheme }}>
<Layout />
</ThemeContext>
</UserContext>
);
}
Now theme changes don't re-render components only using UserContext.
For comprehensive Context patterns, see: research/react-19-comprehensive.md lines 288-303, 1326-1342, 1644-1670.
More from djankies/claude-configs
optimizing-with-react-compiler
Teaches what React Compiler handles automatically in React 19, reducing need for manual memoization. Use when optimizing performance or deciding when to use useMemo/useCallback.
16reviewing-prisma-patterns
Review Prisma code for common violations, security issues, and performance anti-patterns found in AI coding agent stress testing. Use when reviewing Prisma Client usage, database operations, or performing code reviews on projects using Prisma ORM.
8migrating-from-v3
Migrate from Tailwind CSS v3 to v4 including configuration migration (JS to CSS), utility renames, opacity changes, and color system updates. Use when upgrading existing projects to v4.
6implementing-query-pagination
Implement cursor-based or offset pagination for Prisma queries. Use for datasets 100k+, APIs with page navigation, or infinite scroll/pagination mentions.
5using-reducers
Teaches useReducer for complex state logic in React 19. Use when state updates depend on previous state, multiple related state values, or complex update logic.
5implementing-code-splitting
Teaches code splitting with lazy() and Suspense in React 19 for reducing initial bundle size. Use when implementing lazy loading, route-based splitting, or optimizing performance.
5