home / skills / vudovn / antigravity-kit / nextjs-react-expert

nextjs-react-expert skill

/.agent/skills/nextjs-react-expert

This skill helps you optimize Next.js and React performance by eliminating waterfalls, reducing bundle size, and applying server/client optimizations.

npx playbooks add skill vudovn/antigravity-kit --skill nextjs-react-expert

Review the files below or copy the command above to add this skill to your agents.

Files (11)
SKILL.md
9.0 KB
---
name: nextjs-react-expert
description: React and Next.js performance optimization from Vercel Engineering. Use when building React components, optimizing performance, eliminating waterfalls, reducing bundle size, reviewing code for performance issues, or implementing server/client-side optimizations.
allowed-tools: Read, Write, Edit, Glob, Grep, Bash
---

# Next.js & React Performance Expert

> **From Vercel Engineering** - 57 optimization rules prioritized by impact
> **Philosophy:** Eliminate waterfalls first, optimize bundles second, then micro-optimize.

---

## šŸŽÆ Selective Reading Rule (MANDATORY)

**Read ONLY sections relevant to your task!** Check the content map below and load what you need.

> šŸ”“ **For performance reviews: Start with CRITICAL sections (1-2), then move to HIGH/MEDIUM.**

---

## šŸ“‘ Content Map

| File | Impact | Rules | When to Read |
|------|--------|-------|--------------|
| `1-async-eliminating-waterfalls.md` | šŸ”“ **CRITICAL** | 5 rules | Slow page loads, sequential API calls, data fetching waterfalls |
| `2-bundle-bundle-size-optimization.md` | šŸ”“ **CRITICAL** | 5 rules | Large bundle size, slow Time to Interactive, First Load issues |
| `3-server-server-side-performance.md` | 🟠 **HIGH** | 7 rules | Slow SSR, API route optimization, server-side waterfalls |
| `4-client-client-side-data-fetching.md` | 🟔 **MEDIUM-HIGH** | 4 rules | Client data management, SWR patterns, deduplication |
| `5-rerender-re-render-optimization.md` | 🟔 **MEDIUM** | 12 rules | Excessive re-renders, React performance, memoization |
| `6-rendering-rendering-performance.md` | 🟔 **MEDIUM** | 9 rules | Rendering bottlenecks, virtualization, image optimization |
| `7-js-javascript-performance.md` | ⚪ **LOW-MEDIUM** | 12 rules | Micro-optimizations, caching, loop performance |
| `8-advanced-advanced-patterns.md` | šŸ”µ **VARIABLE** | 3 rules | Advanced React patterns, useLatest, init-once |

**Total: 57 rules across 8 categories**

---

## šŸš€ Quick Decision Tree

**What's your performance issue?**

```
🐌 Slow page loads / Long Time to Interactive
  → Read Section 1: Eliminating Waterfalls
  → Read Section 2: Bundle Size Optimization

šŸ“¦ Large bundle size (> 200KB)
  → Read Section 2: Bundle Size Optimization
  → Check: Dynamic imports, barrel imports, tree-shaking

šŸ–„ļø Slow Server-Side Rendering
  → Read Section 3: Server-Side Performance
  → Check: Parallel data fetching, streaming

šŸ”„ Too many re-renders / UI lag
  → Read Section 5: Re-render Optimization
  → Check: React.memo, useMemo, useCallback

šŸŽØ Rendering performance issues
  → Read Section 6: Rendering Performance
  → Check: Virtualization, layout thrashing

🌐 Client-side data fetching problems
  → Read Section 4: Client-Side Data Fetching
  → Check: SWR deduplication, localStorage

✨ Need advanced patterns
  → Read Section 8: Advanced Patterns
```

---

## šŸ“Š Impact Priority Guide

**Use this order when doing comprehensive optimization:**

```
1ļøāƒ£ CRITICAL (Biggest Gains - Do First):
   ā”œā”€ Section 1: Eliminating Waterfalls
   │  └─ Each waterfall adds full network latency (100-500ms+)
   └─ Section 2: Bundle Size Optimization
      └─ Affects Time to Interactive and Largest Contentful Paint

2ļøāƒ£ HIGH (Significant Impact - Do Second):
   └─ Section 3: Server-Side Performance
      └─ Eliminates server-side waterfalls, faster response times

3ļøāƒ£ MEDIUM (Moderate Gains - Do Third):
   ā”œā”€ Section 4: Client-Side Data Fetching
   ā”œā”€ Section 5: Re-render Optimization
   └─ Section 6: Rendering Performance

4ļøāƒ£ LOW (Polish - Do Last):
   ā”œā”€ Section 7: JavaScript Performance
   └─ Section 8: Advanced Patterns
```

---

## šŸ”— Related Skills

| Need | Skill |
|------|-------|
| API design patterns | `@[skills/api-patterns]` |
| Database optimization | `@[skills/database-design]` |
| Testing strategies | `@[skills/testing-patterns]` |
| UI/UX design principles | `@[skills/frontend-design]` |
| TypeScript patterns | `@[skills/typescript-expert]` |
| Deployment & DevOps | `@[skills/deployment-procedures]` |

---

## āœ… Performance Review Checklist

Before shipping to production:

**Critical (Must Fix):**
- [ ] No sequential data fetching (waterfalls eliminated)
- [ ] Bundle size < 200KB for main bundle
- [ ] No barrel imports in app code
- [ ] Dynamic imports used for large components
- [ ] Parallel data fetching where possible

**High Priority:**
- [ ] Server components used where appropriate
- [ ] API routes optimized (no N+1 queries)
- [ ] Suspense boundaries for data fetching
- [ ] Static generation used where possible

**Medium Priority:**
- [ ] Expensive computations memoized
- [ ] List rendering virtualized (if > 100 items)
- [ ] Images optimized with next/image
- [ ] No unnecessary re-renders

**Low Priority (Polish):**
- [ ] Hot path loops optimized
- [ ] RegExp patterns hoisted
- [ ] Property access cached in loops

---

## āŒ Anti-Patterns (Common Mistakes)

**DON'T:**
- āŒ Use sequential `await` for independent operations
- āŒ Import entire libraries when you need one function
- āŒ Use barrel exports (`index.ts` re-exports) in app code
- āŒ Skip dynamic imports for large components/libraries
- āŒ Fetch data in useEffect without deduplication
- āŒ Forget to memoize expensive computations
- āŒ Use client components when server components work

**DO:**
- āœ… Fetch data in parallel with `Promise.all()`
- āœ… Use dynamic imports: `const Comp = dynamic(() => import('./Heavy'))`
- āœ… Import directly: `import { specific } from 'library/specific'`
- āœ… Use Suspense boundaries for better UX
- āœ… Leverage React Server Components
- āœ… Measure performance before optimizing
- āœ… Use Next.js built-in optimizations (next/image, next/font)

---

## šŸŽÆ How to Use This Skill

### For New Features:
1. Check **Section 1 & 2** while building (prevent waterfalls, keep bundle small)
2. Use server components by default (Section 3)
3. Apply memoization for expensive operations (Section 5)

### For Performance Reviews:
1. Start with **Section 1** (waterfalls = biggest impact)
2. Then **Section 2** (bundle size)
3. Then **Section 3** (server-side)
4. Finally other sections as needed

### For Debugging Slow Performance:
1. Identify the symptom (slow load, lag, etc.)
2. Use Quick Decision Tree above
3. Read relevant section
4. Apply fixes in priority order

---

## šŸ“š Learning Path

**Beginner (Focus on Critical):**
→ Section 1: Eliminating Waterfalls
→ Section 2: Bundle Size Optimization

**Intermediate (Add High Priority):**
→ Section 3: Server-Side Performance
→ Section 5: Re-render Optimization

**Advanced (Full Optimization):**
→ All sections + Section 8: Advanced Patterns

---

## šŸ” Validation Script

| Script | Purpose | Command |
|--------|---------|---------|
| `scripts/react_performance_checker.py` | Automated performance audit | `python scripts/react_performance_checker.py <project_path>` |

---

## šŸ“– Section Details

### Section 1: Eliminating Waterfalls (CRITICAL)
**Impact:** Each waterfall adds 100-500ms+ latency
**Key Concepts:** Parallel fetching, Promise.all(), Suspense boundaries, preloading

### Section 2: Bundle Size Optimization (CRITICAL)
**Impact:** Directly affects Time to Interactive, Largest Contentful Paint
**Key Concepts:** Dynamic imports, tree-shaking, barrel import avoidance

### Section 3: Server-Side Performance (HIGH)
**Impact:** Faster server responses, better SEO
**Key Concepts:** Parallel server fetching, streaming, API route optimization

### Section 4: Client-Side Data Fetching (MEDIUM-HIGH)
**Impact:** Reduces redundant requests, better UX
**Key Concepts:** SWR deduplication, localStorage caching, event listeners

### Section 5: Re-render Optimization (MEDIUM)
**Impact:** Smoother UI, less wasted computation
**Key Concepts:** React.memo, useMemo, useCallback, component structure

### Section 6: Rendering Performance (MEDIUM)
**Impact:** Better rendering efficiency
**Key Concepts:** Virtualization, image optimization, layout thrashing

### Section 7: JavaScript Performance (LOW-MEDIUM)
**Impact:** Incremental improvements in hot paths
**Key Concepts:** Loop optimization, caching, RegExp hoisting

### Section 8: Advanced Patterns (VARIABLE)
**Impact:** Specific use cases
**Key Concepts:** useLatest hook, init-once patterns, event handler refs

---

## šŸŽ“ Best Practices Summary

**Golden Rules:**
1. **Measure first** - Use React DevTools Profiler, Chrome DevTools
2. **Biggest impact first** - Waterfalls → Bundle → Server → Micro
3. **Don't over-optimize** - Focus on real bottlenecks
4. **Use platform features** - Next.js has optimizations built-in
5. **Think about users** - Real-world conditions matter

**Performance Mindset:**
- Every `await` in sequence = potential waterfall
- Every `import` = potential bundle bloat
- Every re-render = wasted computation (if unnecessary)
- Server components = less JavaScript to ship
- Measure, don't guess

---

**Source:** Vercel Engineering
**Date:** January 2026
**Version:** 1.0.0
**Total Rules:** 57 across 8 categories

Overview

This skill provides React and Next.js performance optimization guidance distilled from Vercel Engineering. It prioritizes fixes by impact and offers 57 concrete rules across eight categories to eliminate waterfalls, reduce bundle size, and improve server- and client-side performance. Use it as a checklist and decision tree during development, reviews, and debugging.

How this skill works

The skill inspects common performance bottlenecks and recommends prioritized actions: eliminate sequential data fetching, optimize bundles, and then refine server/client rendering and JavaScript hot paths. It surfaces a quick decision tree, a validation checklist, and targeted rules for critical areas like waterfalls and bundle trimming, plus practical anti-patterns to avoid. Follow the impact-priority guide to apply fixes in the order that yields the largest gains.

When to use it

  • Building new pages or features and wanting to prevent regressions
  • Conducting a performance review before shipping to production
  • Debugging slow page loads, long TTI, or LCP issues
  • Reducing large bundle sizes or eliminating unnecessary code shipping
  • Addressing server-side slowness or SSR waterfalls

Best practices

  • Measure first with DevTools and React Profiler before changing code
  • Fix CRITICAL items first: eliminate waterfalls and reduce main bundle size
  • Fetch independent resources in parallel (Promise.all) and use Suspense boundaries
  • Prefer server components when appropriate to reduce client JS
  • Use dynamic imports for large components and avoid barrel exports in app code

Example use cases

  • Performance review: run checklist to find waterfall API calls and large imports
  • Feature implementation: keep main bundle under 200KB and use dynamic imports for heavy libs
  • SSR optimization: parallelize server fetches and add streaming or Suspense boundaries
  • UI lag fix: apply memoization, useMemo/useCallback, and virtualize long lists
  • Client data fetching: enable SWR deduplication and cache frequently used responses

FAQ

What should I fix first?

Start with eliminating waterfalls and then reduce bundle size; these yield the largest improvements.

Is memoization always necessary?

No. Measure to identify hot paths; memoize expensive computations or frequently re-rendered components only when it provides measurable benefit.