vercel-react-best-practices
0
总安装量
1
周安装量
安装命令
npx skills add https://github.com/infinite-loop-factory/app-factory --skill vercel-react-best-practices
Agent 安装分布
amp
1
cline
1
opencode
1
cursor
1
continue
1
kimi-cli
1
Skill 文档
React Best Practices
Comprehensive performance optimization guide for React applications. Contains rules across multiple categories, prioritized by impact to guide automated refactoring and code generation.
When to Apply
Reference these guidelines when:
- Writing new React components
- Implementing data fetching
- Reviewing code for performance issues
- Refactoring existing React code
- Optimizing bundle size or load times
Rule Categories by Priority
| Priority | Category | Impact | Prefix |
|---|---|---|---|
| 1 | Eliminating Waterfalls | CRITICAL | async- |
| 2 | Bundle Size Optimization | CRITICAL | bundle- |
| 3 | Re-render Optimization | MEDIUM | rerender- |
| 4 | Rendering Performance | MEDIUM | rendering- |
| 5 | JavaScript Performance | LOW-MEDIUM | js- |
| 6 | 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 to stream or boundary content
2. Bundle Size Optimization (CRITICAL)
bundle-barrel-imports– Import directly, avoid barrel filesbundle-defer-third-party– Load analytics/logging after initial renderbundle-conditional– Load modules only when feature is activatedbundle-preload– Preload on hover/focus for perceived speed
3. Re-render Optimization (MEDIUM)
rerender-defer-reads– Don’t subscribe to state only used in callbacksrerender-memo– Extract expensive work into memoized componentsrerender-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
4. Rendering Performance (MEDIUM)
rendering-animate-svg-wrapper– Animate div wrapper, not SVG elementrendering-hoist-jsx– Extract static JSX outside componentsrendering-svg-precision– Reduce SVG coordinate precisionrendering-activity– Use Activity component for show/hiderendering-conditional-render– Use ternary, not && for conditionals
5. JavaScript Performance (LOW-MEDIUM)
js-batch-dom-css– Group CSS changes via classes or cssTextjs-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-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
6. Advanced Patterns (LOW)
advanced-event-handler-refs– Store event handlers in refsadvanced-use-latest– useLatest for stable callback refs
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: AGENTS.md