SSR vs SSG vs ISR — Complete Guide
SSR vs SSG vs ISR — Complete Guide: free step-by-step lesson with examples, common mistakes, and interview tips — part of Next.js Tutorial on Toolliyo Academy.
On this page
Next.js Tutorial (LearnHub) · Lesson 31 of 100
SSR vs SSG vs ISR
Beginner ✓ → Intermediate → Advanced → Professional
Intermediate · 2 — Building apps · ~14 min read · Module 4: Auth & APIs
Introduction
You know the basics now. Here we use SSR vs SSG vs ISR in real LearnHub screens — layouts, data, and APIs. Still plain language, just a bit more depth. SSR (Server-Side Rendering) builds HTML on every request. SSG (Static Site Generation) builds HTML at deploy time. ISR (Incremental Static Regeneration) rebuilds static pages in the background after a time interval. LearnHub course marketing pages want SSG for speed, while a student dashboard with fresh progress might use SSR or ISR. Picking the wrong mode wastes money on server load or shows stale data.
Route Handlers are how LearnHub talks to webhooks and mobile clients. Get JSON responses solid here.
When will you use this?
Use Route Handlers when a mobile app, webhook, or external client needs JSON from your server.
- Mobile apps and partner sites call your Next.js Route Handlers for JSON over HTTP.
- Webhook endpoints for payment providers live in app/api routes.
Real-world: LearnHub LMS
The EdTech / LMS team building LearnHub LMS uses SSR vs SSG vs ISR to apply SSR vs SSG vs ISR when building course catalog, lesson player, and progress tracking. students and instructors never see the TypeScript files — they just get a fast, reliable course catalog, lesson player, and progress tracking.
Production-style code
// SSG — static at build
export default async function AboutPage() {
return <h1>About LearnHub</h1>;
}
// ISR — revalidate every 60 seconds
async function getCourses() {
const res = await fetch('https://api.example.com/courses', {
next: { revalidate: 60 }
});
return res.json();
}
export default async function CatalogPage() {
const courses = await getCourses();
return <CourseGrid courses={courses} />;
}
What happens in production: In LearnHub LMS, getting SSR vs SSG vs ISR right means students and instructors trust the course catalog, lesson player, and progress tracking every day.
Lesson example (start here)
Copy this smaller example first. Once it works, compare it with the real-world code above.
// SSG — static at build
export default async function AboutPage() {
return <h1>About LearnHub</h1>;
}
// ISR — revalidate every 60 seconds
async function getCourses() {
const res = await fetch('https://api.example.com/courses', {
next: { revalidate: 60 }
});
return res.json();
}
export default async function CatalogPage() {
const courses = await getCourses();
return <CourseGrid courses={courses} />;
}
Line-by-line walkthrough
| Code | What it means |
|---|---|
// SSG — static at build | Comment — notes for humans; the compiler ignores it. |
export default async function AboutPage() { | Default export — the main page or component this file provides to Next.js. |
return <h1>About LearnHub</h1>; | Returns JSX — what the user sees in the browser. |
} | Closes a block started by { above. |
// ISR — revalidate every 60 seconds | Comment — notes for humans; the compiler ignores it. |
async function getCourses() { | Async function — can await fetch or database calls on the server. |
const res = await fetch('https://api.example.com/courses', { | Fetches data over HTTP — runs on the server in Server Components or in Server Actions. |
next: { revalidate: 60 } | Part of the SSR vs SSG vs ISR example — read it together with the lines before and after. |
}); | Closes a block started by { above. |
return res.json(); | Part of the SSR vs SSG vs ISR example — read it together with the lines before and after. |
} | Closes a block started by { above. |
export default async function CatalogPage() { | Default export — the main page or component this file provides to Next.js. |
const courses = await getCourses(); | Part of the SSR vs SSG vs ISR example — read it together with the lines before and after. |
return <CourseGrid courses={courses} />; | Returns JSX — what the user sees in the browser. |
How it works (big picture)
- Marketing pages with no personal data are perfect for SSG.
- Catalog pages that change hourly use ISR.
- Personalized dashboards often need SSR or client fetch after auth.
Do this on your computer
- Add next: { revalidate: 60 } to a fetch in the catalog page.
- Run npm run build and npm start — note static vs dynamic in the build output.
- Change revalidate to 0 and compare behavior (SSR).
- Read the real-world section and name which part of LearnHub uses this topic.
- Run the example locally with npm run dev and confirm the same behavior.
- Change one value in the example (route, text, or course id) and predict what will happen before you save.
Experiments — try changing this
- Change a string or route in the example and save — watch the browser update.
- Break the code on purpose (remove a bracket), read the error overlay, then fix it.
- Change the API URL or course id and see how the page data changes.
- Use npm run dev while editing SSR vs SSG vs ISR — the page hot-reloads on save.
Remember
SSG = fastest, fixed content. ISR = static + periodic refresh. SSR = fresh HTML every request.
Common questions
When should LearnHub use ISR?
Public course lists that update a few times per hour — not per-second trading data.
How long should I spend on SSR vs SSG vs ISR?
Until you can explain it in your own words and run the example without looking at the answer. Beginners often need 30–60 minutes per new concept; setup lessons may take one afternoon.
What if I get stuck on SSR vs SSG vs ISR?
Re-read the line-by-line walkthrough, check the terminal and browser overlay for errors, and compare your code character-by-character with the example. Search the exact error text — someone else had it too.
Where is SSR vs SSG vs ISR used in real jobs?
See the real-world section above — the same pattern appears in LMS, e-commerce, SaaS, and dashboards. Interviewers ask you to explain it using one concrete example.