Sean's Blog

An image showing avatar

Hi, I'm Sean

這裡記錄我學習網站開發的筆記
歡迎交流 (ゝ∀・)b

LinkedInGitHub

基於檔案的 Next.js 頁面路由

今年下半年接了一個公司的對外專案,因此有 SEO 需求,不知道是不是靜茹給我的勇氣,讓我主動提出可以使用 Next.js 的 SSR 來架構新專案,總之就是且戰且走吧,從零開始一邊做一邊學。

useRouter hook

1// file: <root>/pages/clients/[id]/[projectId].js
2// visit: localhost:3000/clients/sean/project1
3
4import { useRouter } from 'next/router';
5
6function SelectedClientProjectPage() {
7  const router = useRouter();
8
9  console.log(router.pathname); // "clients/[id]/[projectId]"
10  console.log(router.query); // {projectId: "project1", id: "sean"}
11
12  // send a request to some backend server
13  // to fetch the piece of data with an id of router.query.projectId
14
15  return (
16    <div>
17      <h1>The Project Page for a Specific Project for a Selected Client</h1>
18    </div>
19  );
20}
21
22export default SelectedClientProjectPage;

Catch-All Routes

e.g. [...xxx].js

1// file: <root>/pages/blog/[...slug].js
2// visit: localhost:3000/blogs/2023/09
3
4import { useRouter } from 'next/router';
5
6function BlogPostsPage() {
7  const router = useRouter();
8
9  console.log(router.query); // {slug: ["2023", "09"]}
10
11  return (
12    <div>
13      <h1>The Blog Posts</h1>
14    </div>
15  );
16}
17
18export default BlogPostsPage;

Navigating To Dynamic Routes

1import Link from 'next/link';
2
3function ClientsPage() {
4  const clients = [
5    { id: 'sean', name: 'Sean' },
6    { id: 'chi', name: 'Chi' },
7  ];
8
9  return (
10    <div>
11      <h1>The Clients Page</h1>
12      <ul>
13        {clients.map((client) => (
14          <li key={client.id}>
15            <Link href={`/clients/${client.id}`}>{client.name}</Link>
16          </li>
17        ))}
18      </ul>
19    </div>
20  );
21}
22
23export default ClientsPage;

A Different Way Of Setting Link Hrefs

1<Link
2  href={{
3    pathname: '/clients/[id]',
4    query: { id: client.id },
5  }}
6>
7  {client.name}
8</Link>

Navigating Programmatically

1const router = useRouter();
2
3router.push({
4  pathname: '/clients/[id]/[projectId]',
5  query: { id: 'sean', projectId: 'project1' },
6});

Custom 404 Page

1// file: <root>/pages/404.js (Must)
2// visit: localhost:3000/something
3
4function NotFoundPage() {
5  return (
6    <div>
7      <h1>Page not found!</h1>
8    </div>
9  );
10}
11
12export default NotFoundPage;

Public folder

Files and folders stored outside of public/ are NOT made accessible by Next.js - visitors can NOT load files from there.