Migration de composant Pages Router vers App Router

VérifiéSûr

Migrer un composant React du Pages Router vers l'App Router de Next.js. Gère la conversion des méthodes de récupération de données (getServerSideProps, getStaticProps), des patterns de routage, et des hooks comme useRouter et Head. Utile pour moderniser des pages Next.js héritées.

Spar Skills Guide Bot
DeveloppementAvancé
11002/06/2026
Claude CodeCursorWindsurf
#nextjs#pages-router#app-router#migration#component-migration

Recommandé pour

Notre avis

Cette compétence permet de migrer des composants ou pages Next.js du Pages Router vers l'App Router selon une architecture définie.

Points forts

  • Automatise la conversion des fichiers de pages et des API routes
  • Transforme les méthodes de données serveur (getServerSideProps, getStaticProps) en composants serveur asynchrones
  • Gère la séparation entre composants serveur et client
  • Crée automatiquement les fichiers loading.tsx et error.tsx

Limites

  • Nécessite que les fichiers soient déjà conformes à Next.js Pages Router
  • Ne gère pas les cas complexes de routing dynamique imbriqué
  • Requiert une exécution manuelle des commandes de validation
Quand l'utiliser

Lorsqu'un projet Next.js utilisant le Pages Router doit être migré vers l'App Router.

Quand l'éviter

Pour des migrations partielles ou lorsque l'architecture cible n'est pas encore clairement définie.

Analyse de sécurité

Sûr
Score qualité85/100

The skill only performs code analysis, file editing, and runs standard build/lint/test commands (tsc, next build, vitest) for validation. No destructive, exfiltrating, or obfuscated actions are involved.

Aucun point d'attention détecté

Exemples

Migrate a page to App Router
Migrate the file pages/products/[id].tsx to the App Router following the architecture documentation.
Convert legacy data fetching
Convert getServerSideProps in components/UserProfile.tsx to async server component pattern.
Full component migration
I need to migrate my component MyComponent from Pages Router to App Router. The file is at src/components/MyComponent.tsx.

name: migration-migrate-component description: "Use when a component needs migration to the target architecture or framework version." user-invocable: true argument-hint: "[component-file]" allowed-tools: Read, Write, Edit, Bash, Glob, Grep

Migrate a Pages Router component/page to App Router following docs/ARCHITECTURE.md sections 5 and 6.

Component: $ARGUMENTS

Steps

  1. Read docs/ARCHITECTURE.md sections 5 and 6.

  2. Analyze the component/page:

    • Count lines (JSX, logic)
    • List: props, state, effects, data fetching methods
    • Check for getServerSideProps, getStaticProps, getStaticPaths
    • Check for useRouter from next/router
    • Check for Head component usage
    • Map who imports this component
  3. Convert routing:

    • pages/xxx.tsx -> app/xxx/page.tsx
    • pages/xxx/[id].tsx -> app/xxx/[id]/page.tsx
    • pages/api/xxx.ts -> app/api/xxx/route.ts (or Server Action)
  4. Convert data fetching:

    • getServerSideProps -> async Server Component (service + adapter)
    • getStaticProps -> async Server Component + revalidate
    • getStaticPaths -> generateStaticParams()
    • Client-side useEffect + fetch -> React Query hook
  5. Determine Server vs Client:

    • Data fetching only? -> Server Component
    • Has hooks, events, browser APIs? -> Client Component
    • Mixed? -> Split into Server page + Client component
  6. Convert imports:

    • useRouter from next/router -> useRouter + usePathname + useSearchParams from next/navigation
    • Head -> metadata export or generateMetadata()
  7. Create siblings:

    • loading.tsx -- skeleton matching page structure
    • error.tsx -- error boundary ('use client' required)
  8. Type all props.

  9. Decompose if > 200 lines.

  10. Validate:

npx tsc --noEmit
npx next build
npx vitest run --passWithNoTests
Skills similaires