Routing Fundamentals — Complete Guide
Routing Fundamentals — 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 9 of 100
Routing Fundamentals
Beginner → Intermediate → Advanced → Professional
Beginner · 1 — Foundations · ~12 min read · Module 1: Next.js Foundations
Introduction
This lesson is part of the beginner section. We explain Routing Fundamentals slowly, with examples you can copy and run. If something is unclear, read it twice — that is how everyone learns. Routing connects URLs to files. Static segments (courses), dynamic segments ([slug]), and catch-all ([...path]) build LearnHub paths like /courses/nextjs-101/lesson-3. Students bookmark lesson URLs. Instructors share direct links. Routing must be predictable and file-based so the team agrees on structure.
Routing Fundamentals is setup knowledge. Without it, LearnHub will not run. Spend time here until npm run dev works without errors.
When will you use this?
You need this before writing any Next.js code — same as installing Node.js before opening a project.
- Every React/Next.js job expects you to run npx create-next-app and npm run dev on day one.
- Interviewers often ask you to explain the App Router folder structure and Server vs Client Components.
Real-world: Freshdesk-style support portal
The Customer support team building Freshdesk-style support portal uses Routing Fundamentals to link /courses, /courses/[slug], and /dashboard with file-based routes. support agents never see the TypeScript files — they just get a fast, reliable ticket queue and reply interface.
Production-style code
app/
page.tsx → /
courses/page.tsx → /courses
courses/[slug]/page.tsx → /courses/nextjs-101
login/page.tsx → /login
dashboard/page.tsx → /dashboard
What happens in production: In Freshdesk-style support portal, getting Routing Fundamentals right means support agents trust the ticket queue and reply interface every day.
Lesson example (start here)
Copy this smaller example first. Once it works, compare it with the real-world code above.
app/
page.tsx → /
courses/page.tsx → /courses
courses/[slug]/page.tsx → /courses/nextjs-101
login/page.tsx → /login
dashboard/page.tsx → /dashboard
Line-by-line walkthrough
| Code | What it means |
|---|---|
app/ | Part of the Routing Fundamentals example — read it together with the lines before and after. |
page.tsx → / | Part of the Routing Fundamentals example — read it together with the lines before and after. |
courses/page.tsx → /courses | Part of the Routing Fundamentals example — read it together with the lines before and after. |
courses/[slug]/page.tsx → /courses/nextjs-101 | Part of the Routing Fundamentals example — read it together with the lines before and after. |
login/page.tsx → /login | Part of the Routing Fundamentals example — read it together with the lines before and after. |
dashboard/page.tsx → /dashboard | Part of the Routing Fundamentals example — read it together with the lines before and after. |
How it works (big picture)
- Folder names become path segments.
- Brackets mark dynamic params available as params prop in page.tsx.
- No react-router Route JSX — the filesystem is the router.
Do this on your computer
- Create login/page.tsx and dashboard/page.tsx
- Link between them with next/link (next lesson)
- Create courses/[slug]/page.tsx that shows the slug param
- Visit /courses/demo and /courses/other
- 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.
Remember
File path = URL path. [slug] = dynamic segment. Plan LearnHub routes on paper before coding.
Common questions
Route groups (folder)?
Covered in advanced lessons — (marketing) folders omit URL segment.
How long should I spend on Routing Fundamentals?
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 Routing Fundamentals?
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 Routing Fundamentals 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.