跳到主內容

【Next.js】路由機制(動態)

在 Next.js 中,**Dynamic Routes(動態路由)**允許你根據 URL 中的參數來動態建立頁面,這對於像是部落格文章、使用者頁面、商品詳細頁等非常有用。


🗂️ 基本概念

在 Next.js 中,每個檔案都對應一個路由。當你在 app/pages/ 目錄中使用 方括號([param]) 定義檔案名稱時,就代表建立了一個動態路由。

例如:

pages/
  └── blog/
        └── [slug].tsx

這樣的結構可以對應:

  • /blog/hello-world

  • /blog/my-second-post

app/ 目錄中則會是:

app/
  └── blog/
        └── [slug]/
              └── page.tsx

💡 Dynamic Routes 實作(app/

1️⃣ 建立檔案:app/post/[id]/page.tsx

interface PageProps {
  params: { id: string }
}

export default function Post({ params }: PageProps) {
  return <h1>Post ID: {params.id}</h1>
}

// { params }: PageProps
// { params } => 解構,取出物件的 params 屬性
// :PageProps typescript宣告型別
// 直接簡化成 { params }: { params: { id: string } }

🔁 多層動態路由

支援巢狀結構,例如:

app/
  └── user/
        └── [userId]/
              └── post/
                    └── [postId]/
                          └── page.tsx

訪問路徑 /user/1/post/10 對應的 params 為:

params: {
  userId: '1',
  postId: '10'
}

✅ Catch-all 路由(捕捉所有)

你可以使用 [...slug] 來捕捉多層級路徑:

  • app/products/[...slug].tsx 會匹配 /products/a/products/a/b/c

interface PageProps {
  params: {
    slug?: string[];
  };
}

export default function ProductPage({ params }: PageProps) {
  return (
    <div>
      <h1>Products Page</h1>
      <pre>{JSON.stringify(params.slug)}</pre>
    </div>
  );
}

如果要可選,可用 [[...slug]] 表示非必要。


📌 小結

類型 說明 範例
[param] 基本動態路由 /post/1[id].tsx
[...param] 捕捉多層路徑(Catch-all) /docs/a/b[...slug].tsx
[[...param]] 可選 catch-all(Optional) /docs or /docs/a

若你想看實際範例或搭配 getStaticPathsgenerateStaticParams 使用,也可以提出,我可以補上。需要嗎?