🚀 This repository aimed to contains 500 nextjs interview questions & answers with exmample.
No | Contents |
---|---|
1 | Common |
2 | Pages Router |
3 | App Router |
4 | Others |
-
Next.js is a React framework for building full-stack web applications.
-
Using command
npx create-next-app@latest
-
It contains React components that are automatically routed based on their file name.
-
Routing based on the file structure in the
pages or app
directory. -
- Server Side Rendering (SSR): Next.js allows rendering React components on the server before sending them to the client, improving performance and SEO.
- Static Site Generation (SSG): It pre-renders pages at build time, useful for blogs or e-commerce sites.
- API Routes: You can build a backend using API routes in the same codebase without needing an external server.
- File Based Routing: Next.js automatically creates routes based on the file structure inside the pages directory.
- Client Side Rendering (CSR): Like React, Next.js also supports traditional client-side rendering.
- Incremental Side Rendering:
- Image Optimization: Built-in image optimization capabilities that reduce image sizes and enhance loading times.
- Automatic Code Splitting: Next.js splits the code into smaller bundles, which are loaded only when required, improving performance.
- TypeScript Support: Native support for TypeScript, enabling strict typing and better developer experience.
- Incremental Static Regeneration (ISR): Pages can be statically generated at runtime and updated incrementally.
- Fast Refresh: Provides an instant feedback loop while coding, similar to React's hot reloading.
-
Feature Next.js React.js Rendering Supports Server-Side Rendering (SSR), Static Site Generation (SSG), and Client-Side Rendering (CSR). Only supports Client-Side Rendering (CSR) by default. Routing Built-in file-based routing system. Automatically generates routes based on the folder structure. No built-in routing. Requires libraries like React Router. SEO Excellent for SEO as it supports SSR and SSG, allowing pre-rendered content to be indexed by search engines. Limited SEO capabilities due to client-side rendering. Additional work is needed for SEO optimization. Performance Faster initial page load due to SSR, automatic code splitting, and static generation. May have slower page loads for large apps since everything is rendered on the client. Configuration Minimal configuration required. Comes with SSR, SSG, and routing out of the box. Requires manual setup for SSR, routing, and other advanced features. Learning Curve Slightly steeper due to built-in advanced features like SSR, SSG, and API routes. Easier to learn initially, but requires additional tools for SSR and routing. API Routes Built-in API routes that can handle backend logic within the same project. No support for API routes; requires external tools for backend development. Code Splitting Automatically splits code into smaller bundles, loading only what’s needed for a specific page. Requires manual code splitting or use of lazy loading to optimize performance. Deployment Optimized for easy deployment on platforms like Vercel (creators of Next.js) and supports serverless functions. Deployment typically requires additional configuration for optimized hosting and SSR. Image Optimization Has a built-in Image component for automatic image resizing and optimization. Does not provide image optimization; developers need third-party libraries for that. -
Incremental Static Regeneration is a technique in Next.js that allows you to update static pages at runtime without rebuilding the entire site. This feature introduces a seamless way to serve both static and dynamic content by revalidating and regenerating pages in the background.
-
A component for client-side navigation between pages.
import Link from 'next/link' <Link href="/">Home</Link> <Link href="/about">About</Link>
-
A hook that allows access to the router object and perform navigation. The
useRouter
hook allows you to programmatically change routes inside Client Components. -
Using useRouter() hook.
const router = userRouter(); function handleClick() { router.push(`/path`); } <button onClick={handleClick}>Go There</button>;
router.push(href: string, { scroll: boolean })
-
Middleware allows you to run code before a request is completed. Then, based on the incoming request, you can modify the response by rewriting, redirecting, modifying the request or response headers, or responding directly.
import { NextResponse } from "next/server"; // This function can be marked `async` if using `await` inside export function middleware(request) { return NextResponse.redirect(new URL("/home", request.url)); } // See "Matching Paths" below to learn more export const config = { matcher: "/about/:path*", };
-
Using CSS modules with a .module.css file extension.
-
Pre-rendering pages at build time. If a page uses Static Generation, the page HTML is generated at build time.
-
Rendering pages on each request. If a page uses Server-side Rendering, the page HTML is generated on each request.
-
Re-generating static pages at runtime as traffic comes in.
-
A component that optimizes images for faster loading.
export default function Page() { return ( <Image src={profilePic} alt="Picture of the author" // width={500} automatically provided // height={500} automatically provided // blurDataURL="data:..." automatically provided // placeholder="blur" // Optional blur-up while loading /> ); }
-
A configuration file to customize Next.js settings.
// @ts-check /** @type {import('next').NextConfig} */ const nextConfig = { /* config options here */ }; module.exports = nextConfig;
-
By adding a tsconfig.json file.
-
A feature to create API endpoints in the
pages/api
orapp/api
directory. It allow you to create custom request handlers for a given route using the Web Request and Response APIs. -
By connecting the git/github repository to Vercel and deploying it.
-
Generating HTML for pages in advance, instead of on each request.
-
Static site generation (SSG) pre-renders at build time, server side rendering (SSR) pre-renders on each request.
-
There are a few ways you can handle redirects in Next.js. One of them is by configuring redirects in next.config.js.
module.exports = { async redirects() { return [ { source: "/about", destination: "/about-us", permanent: true, }, ]; }, };
-
A component for modifying the of a page.
-
A folder for static assets to be served from the root URL.
-
Using getStaticProps or getServerSideProps in server side.
// getStaticProps export async function getStaticProps() { const res = await fetch("https://api.github.com/repos/vercel/next.js"); const repo = await res.json(); return { props: { repo } }; } export default function Page({ repo }) { return repo.stargazers_count; }
// getServerSideProps export async function getServerSideProps() { // Fetch data from external API const res = await fetch("https://api.github.com/repos/vercel/next.js"); const repo = await res.json(); // Pass data to the page via props return { props: { repo } }; } export default function Page({ repo }) { return ( <main> <p>{repo.stargazers_count}</p> </main> ); }
-
A feature to load components or modules dynamically.
const ComponentA = dynamic(() => import("../components/A")); const ComponentB = dynamic(() => import("../components/B"));
-
By adding them to .env.local and accessing via process.env.
-
Determines how to handle missing paths, with true, false, or ‘blocking’.
-
A way to customize the server-side behavior, e.g., with Express.
import { createServer } from "http"; import { parse } from "url"; import next from "next"; const port = parseInt(process.env.PORT || "3000", 10); const dev = process.env.NODE_ENV !== "production"; const app = next({ dev }); const handle = app.getRequestHandler(); app.prepare().then(() => { createServer((req, res) => { const parsedUrl = parse(req.url, true); handle(req, res, parsedUrl); }).listen(port); console.log( `> Server listening at http://localhost:${port} as ${ dev ? "development" : process.env.NODE_ENV }` ); });
-
To manage the document head for meta tags, title,description, og etc.
-
To export a static version of the Next.js app.
-
By using the built-in font optimization feature.
-
Port 3000.
-
By configuring headers in next.config.js.
-
A feature for quick feedback when editing React components.
-
By adding a babel.config.js file.
-
By configuring i18n settings in next.config.js.
-
A development mode only feature for highlighting potential problems in an application. It helps to identify unsafe lifecycles, legacy API usage, and a number of other features.
module.exports = { reactStrictMode: true, };
Note: Since Next.js 13.5.1, Strict Mode is true by default with app router, so the above configuration is only necessary for pages. You can still disable Strict Mode by setting
reactStrictMode: false
. -
A single router instance accessible across the application.
-
Using
useEffect
and fetch or any other data fetching library likeaxios
,fetch
orswr
by Next.js team. -
To manage SEO metadata in a Next.js application.
-
By installing tailwindcss and configuring it with PostCSS.
-
By installing next-i18next and setting up the configuration in next.config. js.
-
To optimize loading third-party scripts.
import Script from "next/script"; export default function Dashboard() { return ( <> <Script src="https://example.com/script.js" /> </> ); }
-
By using the next/font package or including fonts in the public directory.
import localFont from "next/font/local"; // Font files can be colocated inside of `app` const myFont = localFont({ src: "./my-font.woff2", display: "swap", }); export default function RootLayout({ children }) { return ( <html lang="en" className={myFont.className}> <body>{children}</body> </html> ); }
-
By using Apollo Client or another GraphQL client.
-
It enables the use of the SWC compiler for minification.
-
To enable composition of multiple plugins in Next.js configuration.
-
An application that uses both static generation and server side rendering.
-
It configures whether to include a trailing slash in the URLs.
module.exports = { trailingSlash: true, };
-
push
adds a new entry in the history stack,replace
replaces the current entry. -
It disabled server-side rendering for the dynamically imported component.
const ComponentC = dynamic(() => import("../components/C"), { ssr: false });
Note: ssr: false option will only work for client components, move it into client components ensure the client code-splitting working properly.
-
By using plugins like next-pwa and configuring next.config.js.
-
By including the Google Analytics script in _app.js or _document.js.
import { GoogleAnalytics } from "@next/third-parties/google"; export default function RootLayout({ children }) { return ( <html lang="en"> <body>{children}</body> <GoogleAnalytics gaId="G-XYZ" /> </html> ); }
-
To run code before a request is completed.
-
By setting up Apollo Provider in _app.js and creating a client.
-
Configuration exposed to the browser.
-
Create a directory into pages directory & create index file.
pages/index.jsx // / pages/blog/index.jsx // /blog
-
By using square brackets in the filename
pages/blogs/[id].js.pages // /blogs/1, /blogs/2, /blogs/... blogs/[id]/index.js // /blogs/1, /blogs/2, /blogs/... app/products[id]/page.jsx // /products/1, /products/2, /products/... pages/[...products]/index.js // (products/1, products/2, products/...) pages/[[...products]]/index.js // (products, products/1, products/2, products/...)
-
A custom App component that initializes pages and can add global styles or layout components.
-
A custom Document component that allows customization of the HTML document structure.
-
By adding a 404.js file in the pages directory.
-
getStaticProps fetches data at build time, while getServerSideProps fetches data on each request.
-
A function used for static site generation to fetch data at build time.
export async function getStaticProps() { const res = await fetch("https://api.github.com/repos/vercel/next.js"); const repo = await res.json(); return { props: { repo } }; } export default function Page({ repo }) { return repo.stargazers_count; }
-
A function used for server-side rendering to fetch data on each request.
export async function getServerSideProps() { // Fetch data from external API const res = await fetch("https://api.github.com/repos/vercel/next.js"); const repo = await res.json(); // Pass data to the page via props return { props: { repo } }; } export default function Page({ repo }) { return ( <main> <p>{repo.stargazers_count}</p> </main> ); }
-
A function used with getStaticProps to specify dynamic routes to be pre-rendered.
export async function getStaticPaths() { return { paths: [ { params: { name: "next.js", }, }, ], }; } export async function getStaticProps() { const res = await fetch("https://api.github.com/repos/vercel/next.js"); const repo = await res.json(); return { props: { repo } }; } export default function Page({ repo }) { return repo.stargazers_count; }
-
By importing the CSS file in _app.js.
-
A hook for handling translations when using i18n.
-
By adding _error.js in the pages directory.
-
Accelerated Mobile Pages, a framework for fast-loading mobile pages.
-
By adding amp attribute to a page component.
-
To optimize and serve images in a Next.js application.
-
For client-side navigation between pages.
-
pages contains routable components, components contains reusable UI components.
-
Using middleware functions in next.config.js.
-
By customizing the webpack configuration in next.config.js.
-
Client-side rendering happens in the browser, server-side rendering happens on the server.
-
Automatically determining if a page can be statically generated.
-
Using useEffect and fetch or other data fetching libraries.
"use client"; import { useState, useEffect } from "react"; export function Posts() { const [posts, setPosts] = useState(null); useEffect(() => { async function fetchPosts() { const res = await fetch("https://api.vercel.app/blog"); const data = await res.json(); setPosts(data); } fetchPosts(); }, []); if (!posts) return <div>Loading...</div>; return ( <ul> {posts.map((post) => ( <li key={post.id}>{post.title}</li> ))} </ul> ); }
-
Using libraries like AuthJS, JWT or custom authentication logic.
-
_app.js is for global components,
_document.js is for modifying the HTML document structure.
-
By adding files to the
pages/api
orapp/api
directory. -
Incremental Static Regeneration, updating static pages after build without redeploying.
-
By extending the Webpack configuration in next.config.js.
module.exports = { webpack: ( config, { buildId, dev, isServer, defaultLoaders, nextRuntime, webpack } ) => { // Important: return the modified config return config; }, };
-
It provides type definitions for TypeScript support in Next.js.
-
Using the file-based routing system in the pages directory.
-
To enable dynamic imports and code splitting.
"use client"; import { useState } from "react"; import dynamic from "next/dynamic"; // Client Components: const ComponentA = dynamic(() => import("../components/A")); const ComponentB = dynamic(() => import("../components/B")); const ComponentC = dynamic(() => import("../components/C"), { ssr: false }); export default function ClientComponentExample() { const [showMore, setShowMore] = useState(false); return ( <div> {/* Load immediately, but in a separate client bundle */} <ComponentA /> {/* Load on demand, only when/if the condition is met */} {showMore && <ComponentB />} <button onClick={() => setShowMore(!showMore)}>Toggle</button> {/* Load only on the client side */} <ComponentC /> </div> ); }
-
Using the Head component from next/head.
export const metadata = { title: "NextJS", description: "A React Framework for building full-stack web applications", }; export default function Page() {}
-
To compose multiple plugins in next.config.js.
-
Using client-side form handling or API routes for server-side handling.
-
By creating a Redux store and integrating it with _app.js.
-
To handle routing and navigation within a Next.js app.
-
Using libraries like styled-components or Emotion.
-
By installing sass and importing .scss files in your components.
next.config.js
import type { NextConfig } from "next"; const nextConfig: NextConfig = { sassOptions: { implementation: "sass-embedded", }, }; export default nextConfig;
app/variables.module.scss
$primary-color: #64ff00; :export { primaryColor: $primary-color; }
app/page.jsx
import variables from "./variables.module.scss"; export default function Page() { return <h1 style={{ color: variables.primaryColor }}>Hello, Next.js!</h1>; }
-
It allows you to specify a base path for the application.
-
By creating a 500.js file in the pages directory.
export default function Custom500() { return <h1>500 - Server-side error occurred</h1>; }
-
Configuration only available on the server side.
-
To customize the error page for HTTP errors.
-
Create a directory into app directory & create page file.
app/page.jsx // / app/blog/page.jsx // /blog
-
By setting headers in the API route handlers.
-
To map an incoming request path to a different destination path.
-
Using libraries like cookie or js-cookie to set and retrieve cookies.
[:arrow_up: Back to Top](#table-of-content
-
To configure and enable Progressive Web App features in Next.js.
-
To generate sitemaps for a Next.js application.