home / skills / jarrodwatts / claude-code-config / react-useeffect
This skill guides you on when to use React useEffect, optimize data fetching, and apply alternatives for derived state and events.
npx playbooks add skill jarrodwatts/claude-code-config --skill react-useeffectReview the files below or copy the command above to add this skill to your agents.
---
name: react-useeffect
description: React useEffect best practices from official docs. Use when writing/reviewing useEffect, useState for derived values, data fetching, or state synchronization. Teaches when NOT to use Effect and better alternatives.
---
# You Might Not Need an Effect
Effects are an **escape hatch** from React. They let you synchronize with external systems. If there is no external system involved, you shouldn't need an Effect.
## Quick Reference
| Situation | DON'T | DO |
|-----------|-------|-----|
| Derived state from props/state | `useState` + `useEffect` | Calculate during render |
| Expensive calculations | `useEffect` to cache | `useMemo` |
| Reset state on prop change | `useEffect` with `setState` | `key` prop |
| User event responses | `useEffect` watching state | Event handler directly |
| Notify parent of changes | `useEffect` calling `onChange` | Call in event handler |
| Fetch data | `useEffect` without cleanup | `useEffect` with cleanup OR framework |
## When You DO Need Effects
- Synchronizing with **external systems** (non-React widgets, browser APIs)
- **Subscriptions** to external stores (use `useSyncExternalStore` when possible)
- **Analytics/logging** that runs because component displayed
- **Data fetching** with proper cleanup (or use framework's built-in mechanism)
## When You DON'T Need Effects
1. **Transforming data for rendering** - Calculate at top level, re-runs automatically
2. **Handling user events** - Use event handlers, you know exactly what happened
3. **Deriving state** - Just compute it: `const fullName = firstName + ' ' + lastName`
4. **Chaining state updates** - Calculate all next state in the event handler
## Decision Tree
```
Need to respond to something?
├── User interaction (click, submit, drag)?
│ └── Use EVENT HANDLER
├── Component appeared on screen?
│ └── Use EFFECT (external sync, analytics)
├── Props/state changed and need derived value?
│ └── CALCULATE DURING RENDER
│ └── Expensive? Use useMemo
└── Need to reset state when prop changes?
└── Use KEY PROP on component
```
## Detailed Guidance
- [Anti-Patterns](./anti-patterns.md) - Common mistakes with fixes
- [Better Alternatives](./alternatives.md) - useMemo, key prop, lifting state, useSyncExternalStore
This skill teaches React useEffect best practices distilled from official guidance. It helps you decide when to use effects, when to avoid them, and which alternatives (useMemo, key prop, event handlers, lifting state) lead to simpler, safer components. Use it while writing or reviewing components that synchronize state, fetch data, or derive values.
The skill inspects component intent and common patterns to recommend whether an effect is necessary. It flags anti-patterns such as using useState + useEffect for derived values, chaining state updates in effects, or using effects for event responses. When an effect is appropriate it suggests correct cleanup and alternatives like useSyncExternalStore or framework data fetching.
When is useEffect the right choice?
Use it when you must interact with external systems, run one-time lifecycle work, or subscribe to data sources that live outside React.
What should I do instead of using useEffect for derived values?
Compute the derived value during render. If the computation is expensive, wrap it in useMemo.