skills/nextjs/nextjs-optimization/SKILL.md
Optimize images, fonts, scripts, and metadata for Next.js performance and Core Web Vitals. Use when configuring next/image for LCP, next/font for zero layout shift, next/script loading strategies, or generateMetadata for SEO.
npx skillsauth add hoangnguyen0403/agent-skills-standard nextjs-optimizationInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Core optimization primitives provided by Next.js. Monitor First, Optimize Later.
next/speed-insights, React Profiler.Always use next/image to prevent CLS and enable automatic optimization:
See implementation examples
Use next/font for zero layout shift — self-hosts fonts and adds font-display: swap:
See implementation examples
See implementation examples
Use next/script with appropriate loading strategies:
beforeInteractive: Critical scripts (polyfills).afterInteractive: Analytics (Google Analytics).lazyOnload: Chat widgets, social embeds.@next/bundle-analyzer. Prune heavy libraries; use ESM-tree-shakable dependencies.dynamic imports with Suspense for large components not needed at initial render.ppr: true (Partial Prerendering) in Next.js 15+ for static shell + dynamic islands.<img> tag: Use next/image to prevent CLS and enable automatic optimization.next/font to self-host and eliminate layout shift._document.tsx: Use export const metadata or generateMetadata().<head>: Use next/script with appropriate strategy.development
Summarizes GitHub PR, GitLab MR, or Azure DevOps PR metadata, review threads, changed files, and template completeness. Use during review-ticket or code-review workflows when PR/MR context exists.
tools
Development tools, linting, and build config for TypeScript. Use when configuring ESLint, Prettier, Jest, Vitest, tsconfig, or any TS build tooling.
development
Validate input, secure auth tokens, and prevent injection attacks in TypeScript. Use when validating input, handling auth tokens, sanitizing data, or managing secrets and sensitive configuration.
development
Apply modern TypeScript standards for type safety and maintainability. Use when working with types, interfaces, generics, enums, unions, or tsconfig settings.