react-best-practices
React 19+ performance optimization guidelines for modern React applications without framework dependencies. This skill should be used when writing, reviewing, or refactoring React code to ensure optimal performance patterns. Triggers when working in *.tsx files on tasks involving React components, hooks, data fetching, bundle optimization, or performance improvements.
SKILL.md
| Name | react-best-practices |
| Description | React 19+ performance optimization guidelines for modern React applications without framework dependencies. This skill should be used when writing, reviewing, or refactoring React code to ensure optimal performance patterns. Triggers when working in *.tsx files on tasks involving React components, hooks, data fetching, bundle optimization, or performance improvements. |
name: react-best-practices description: React 19+ performance optimization guidelines for modern React applications without framework dependencies. This skill should be used when writing, reviewing, or refactoring React code to ensure optimal performance patterns. Triggers when working in *.tsx files on tasks involving React components, hooks, data fetching, bundle optimization, or performance improvements. license: MIT metadata: author: do-ob version: "1.0.0"
React 19+ Performance Best Practices
Comprehensive performance optimization guide for React 19+ applications. Contains 35+ rules across 7 categories, prioritized by impact to guide automated refactoring and code generation.
When to Apply
Reference these guidelines when:
- Writing new React components or hooks
- Implementing data fetching (client-side)
- Reviewing code for performance issues
- Refactoring existing React code
- Optimizing bundle size or load times
- Working with React 19+ features (use(), Activity, etc.)
Rule Categories by Priority
| Priority | Category | Impact | Prefix |
|---|---|---|---|
| 1 | Eliminating Waterfalls | CRITICAL | async- |
| 2 | Bundle Size Optimization | CRITICAL | bundle- |
| 3 | Client-Side Data Fetching | MEDIUM-HIGH | client- |
| 4 | Re-render Optimization | MEDIUM | rerender- |
| 5 | Rendering Performance | MEDIUM | rendering- |
| 6 | JavaScript Performance | LOW-MEDIUM | js- |
| 7 | Advanced Patterns | LOW | advanced- |
Quick Reference
1. Eliminating Waterfalls (CRITICAL)
async-defer-await- Move await into branches where actually usedasync-parallel- Use Promise.all() for independent operationsasync-dependencies- Use better-all for partial dependenciesasync-suspense-boundaries- Use Suspense + use() hook to stream content
2. Bundle Size Optimization (CRITICAL)
bundle-barrel-imports- Import directly, avoid barrel filesbundle-dynamic-imports- Use React.lazy() for heavy componentsbundle-defer-third-party- Load analytics/logging after hydrationbundle-conditional- Load modules only when feature is activatedbundle-preload- Preload on hover/focus for perceived speed
3. Client-Side Data Fetching (MEDIUM-HIGH)
client-swr-dedup- Use SWR/TanStack Query for automatic request deduplicationclient-event-listeners- Deduplicate global event listenersclient-passive-event-listeners- Use passive listeners for scroll performanceclient-localstorage-schema- Version and minimize localStorage data
4. Re-render Optimization (MEDIUM)
rerender-defer-reads- Don't subscribe to state only used in callbacksrerender-memo- Extract expensive work into memoized componentsrerender-memo-with-default-value- Extract default non-primitive values to constantsrerender-simple-expression-in-memo- Don't wrap simple expressions in useMemorerender-dependencies- Use primitive dependencies in effectsrerender-derived-state- Subscribe to derived booleans, not raw valuesrerender-functional-setstate- Use functional setState for stable callbacksrerender-lazy-state-init- Pass function to useState for expensive valuesrerender-transitions- Use startTransition for non-urgent updates
5. Rendering Performance (MEDIUM)
rendering-activity- Use Activity component for show/hide (React 19)rendering-animate-svg-wrapper- Animate div wrapper, not SVG elementrendering-conditional-render- Use ternary, not && for conditionalsrendering-content-visibility- Use content-visibility for long listsrendering-hoist-jsx- Extract static JSX outside componentsrendering-hydration-no-flicker- Prevent hydration mismatch without flickeringrendering-svg-precision- Reduce SVG coordinate precisionrendering-usetransition-loading- Use useTransition over manual loading states
6. JavaScript Performance (LOW-MEDIUM)
js-batch-dom-css- Avoid layout thrashing with batched DOM operationsjs-index-maps- Build Map for repeated lookupsjs-cache-property-access- Cache object properties in loopsjs-cache-function-results- Cache function results in module-level Mapjs-cache-storage- Cache localStorage/sessionStorage readsjs-combine-iterations- Combine multiple filter/map into one loopjs-length-check-first- Check array length before expensive comparisonjs-early-exit- Return early from functionsjs-hoist-regexp- Hoist RegExp creation outside loopsjs-min-max-loop- Use loop for min/max instead of sortjs-set-map-lookups- Use Set/Map for O(1) lookupsjs-tosorted-immutable- Use toSorted() for immutability
7. Advanced Patterns (LOW)
advanced-event-handler-refs- Store event handlers in refsadvanced-use-latest- useEffectEvent for stable callback refs (experimental)
How to Use
Read individual rule files for detailed explanations and code examples:
rules/async-parallel.md
rules/bundle-barrel-imports.md
rules/_sections.md
Each rule file contains:
- Brief explanation of why it matters
- Incorrect code example with explanation
- Correct code example with explanation
- Additional context and references
Full Compiled Document
For the complete guide with all rules expanded: SKILL.md
Key Differences from Next.js Version
This skill focuses on pure React 19+ without framework-specific features:
- Uses
React.lazy()instead ofnext/dynamic - Client-side data fetching with SWR/TanStack Query
- No server-side rendering optimizations
- No API route patterns
- Emphasizes modern React 19 features (
use()hook,Activitycomponent) - Framework-agnostic bundler configuration (Vite, webpack, etc.)
React 19+ Specific Features
This guide includes React 19-specific optimizations:
use()hook - For unwrapping promises in Suspense boundariesActivitycomponent - For preserving state/DOM on visibility toggle- Async transitions - Enhanced useTransition with async support
- Experimental
useEffectEvent- For stable callback references