react-refactor
0
总安装量
5
周安装量
安装命令
npx skills add https://github.com/pproenca/dot-skills --skill react-refactor
Agent 安装分布
claude-code
5
opencode
4
codex
4
gemini-cli
3
amp
2
kimi-cli
2
Skill 文档
React Refactor Best Practices
Architectural refactoring guide for React applications. Contains 40 rules across 7 categories, prioritized by impact from critical (component and state architecture) to incremental (refactoring safety).
When to Apply
- Refactoring existing React codebases or planning large-scale restructuring
- Reviewing PRs for architectural issues and code smells
- Decomposing oversized components into focused units
- Extracting reusable hooks from component logic
- Improving testability of React code
- Reducing coupling between feature modules
Rule Categories
| Category | Impact | Rules | Key Topics |
|---|---|---|---|
| Component Architecture | CRITICAL | 8 | Compound components, headless pattern, composition over props, client boundaries |
| State Architecture | CRITICAL | 7 | Colocation, state machines, URL state, derived values |
| Hook Patterns | HIGH | 6 | Single responsibility, naming, dependency stability, composition |
| Component Decomposition | HIGH | 6 | Scroll test, extraction by change reason, view/logic separation |
| Coupling & Cohesion | MEDIUM | 4 | Dependency injection, circular deps, stable imports, barrel-free |
| Data & Side Effects | MEDIUM | 4 | Server-first fetch, TanStack Query, error boundaries |
| Refactoring Safety | LOW-MEDIUM | 5 | Characterization tests, behavior testing, integration tests |
Quick Reference
Critical patterns â get these right first:
- Use compound components instead of props explosion
- Colocate state with the components that use it
- Use state machines for complex UI workflows
- Separate container logic from presentational components
Common mistakes â avoid these anti-patterns:
- Lifting state to App when only one component reads it
- Using context for rapidly-changing values
- Monolithic hooks that fetch + transform + cache
- Testing implementation details instead of behavior
Table of Contents
- Component Architecture â CRITICAL
- 1.1 Apply Interface Segregation to Component Props â CRITICAL (prevents 30-50% of unnecessary re-renders)
- 1.2 Colocate Files by Feature Instead of Type â CRITICAL (reduces cross-directory navigation by 70%)
- 1.3 Convert Render Props to Custom Hooks â CRITICAL (eliminates 2-4 levels of nesting)
- 1.4 Extract Headless Components for Logic Reuse â CRITICAL (5x more reuse scenarios)
- 1.5 Prefer Composition Over Props Explosion â CRITICAL (reduces prop count by 50-70%)
- 1.6 Separate Container Logic from Presentational Components â CRITICAL (enables independent testing)
- 1.7 Use Compound Components for Implicit State Sharing â CRITICAL (reduces API surface by 60%)
- 1.8 Push Client Boundaries to Leaf Components â HIGH (keeps 60-80% server-rendered)
- State Architecture â CRITICAL
- 2.1 Colocate State with Components That Use It â CRITICAL (reduces prop passing by 60%)
- 2.2 Derive Values Instead of Syncing State â CRITICAL (eliminates double-render cycle)
- 2.3 Lift State Only When Multiple Components Read It â CRITICAL (eliminates unnecessary parent re-renders)
- 2.4 Use Context for Rarely-Changing Values Only â CRITICAL (5-50x fewer re-renders)
- 2.5 Use State Machines for Complex UI Workflows â CRITICAL (reduces valid states from 2^n to N)
- 2.6 Use URL Parameters as State for Shareable Views â CRITICAL (enables deep linking and sharing)
- 2.7 Use useReducer for Multi-Field State Transitions â CRITICAL (eliminates impossible states)
- Hook Patterns â HIGH
- 3.1 Avoid Object and Array Dependencies in Custom Hooks â HIGH (prevents effect re-execution every render)
- 3.2 Compose Hooks Instead of Nesting Them â HIGH (flattens dependency graph)
- 3.3 Extract Logic into Custom Hooks When Behavior Is Nameable â HIGH (40-60% shorter components)
- 3.4 Follow Hook Naming Conventions for Discoverability â HIGH (reduces navigation time by 40%)
- 3.5 Keep Custom Hooks to a Single Responsibility â HIGH (3x easier to test)
- 3.6 Stabilize Hook Dependencies with Refs and Callbacks â HIGH (prevents infinite loops)
- Component Decomposition â HIGH
- 4.1 Apply the Scroll Test to Identify Oversized Components â HIGH (3x faster code review)
- 4.2 Complete Component Extraction Without Half-Measures â HIGH (enables independent testing and reuse)
- 4.3 Extract Components by Independent Change Reasons â HIGH (70% fewer files touched per change)
- 4.4 Extract Pure Functions from Component Bodies â HIGH (10x faster unit tests)
- 4.5 Inline Premature Abstractions Before Re-Extracting â HIGH (40-60% simpler code)
- 4.6 Separate View Layer from Business Logic â HIGH (5x faster test suite)
- Coupling & Cohesion â MEDIUM
- 5.1 Break Circular Dependencies with Intermediate Modules â MEDIUM (eliminates undefined-at-import-time bugs)
- 5.2 Import from Stable Public API Surfaces Only â MEDIUM (enables internal refactoring)
- 5.3 Use Barrel-Free Feature Modules for Clean Dependencies â MEDIUM (200-800ms build reduction)
- 5.4 Use Dependency Injection for External Services â MEDIUM (3x faster test setup)
- Data & Side Effects â MEDIUM
- 6.1 Fetch Data on the Server by Default â MEDIUM (reduces client JS by 30-60%)
- 6.2 Place Error Boundaries at Data Fetch Granularity â MEDIUM (errors isolated to affected section)
- 6.3 Use Context Module Pattern for Action Colocation â MEDIUM (centralizes data mutations)
- 6.4 Use TanStack Query for Client-Side Server State â MEDIUM (eliminates 80% of fetch boilerplate)
- Refactoring Safety â LOW-MEDIUM
- 7.1 Avoid Snapshot Tests for Refactored Components â LOW-MEDIUM (eliminates false test failures)
- 7.2 Extract Pure Functions to Increase Testability â LOW-MEDIUM (10x faster test execution)
- 7.3 Prefer Integration Tests for Component Verification â LOW-MEDIUM (catches 40% more bugs)
- 7.4 Test Component Behavior Not Implementation Details â LOW-MEDIUM (5x fewer test updates)
- 7.5 Write Characterization Tests Before Refactoring â LOW-MEDIUM (catches 90% of unintended changes)
References
- https://react.dev
- https://react.dev/learn/thinking-in-react
- https://kentcdodds.com/blog/application-state-management-with-react
- https://testing-library.com/docs/guiding-principles
- https://patterns.dev
Related Skills
- For React 19 API best practices, see
reactskill - For application performance optimization, see
react-optimiseskill - For client-side form handling, see
react-hook-formskill