【React 學習筆記 EP.17】巢狀路由

更新 發佈閱讀 4 分鐘

什麼是巢狀路由?

巢狀路由就是在一個路由裡面,再放入子路由。想像你打開「設定」頁面,左邊選單不變,右邊內容根據你點的選項切換,外層不動,只有內部區塊在變化,這就是巢狀路由。

巢狀路由概念

  1. 父路由:外層的頁面,負責提供共用的版面結構,例如導覽列或側邊欄。
  2. 子路由:嵌在父路由裡面的頁面,會根據網址變化替換顯示的內容。
  3. <Outlet />:Router 提供的特殊元件,放在父路由的元件裡,用來標記「子路由的內容要顯示在這裡」。

巢狀路由語法

  1. <Route path="dashboard">:定義父路由的路徑。
  2. element={<Dashboard />}:指定父路由對應的元件。
  3. <Route>:寫在父 <Route> 標籤之間,定義子路由。
  4. path="profile":子路由路徑,網址自動組成 /dashboard/profile
  5. index:預設子路由,當使用者只進入 /dashboard 時顯示的內容。
  6. <Outlet />:放在父元件中,渲染匹配到的子路由元件。
import { BrowserRouter, Routes, Route, Outlet, Link } from "react-router-dom";

// 提供共用版面與導覽
function Dashboard() {
return (
<div>
<nav>
<Link to="profile">個人資料</Link> | {/* 連結到子路由 */}
<Link to="settings">設定</Link>
</nav>
<Outlet /> {/* 子路由的內容會顯示在這裡 */}
</div>
);
}

// Route 包 Route 就是巢狀路由
export default function App() {
return (
<BrowserRouter>
<Routes>
<Route path="dashboard" element={<Dashboard />}> {/* 父路由 */}
<Route index element={<p>歡迎來到儀表板</p>} /> {/* 預設子路由 */}
<Route path="profile" element={<p>這是個人資料頁</p>} /> {/* 子路由 */}
<Route path="settings" element={<p>這是設定頁</p>} /> {/* 子路由 */}
</Route>
</Routes>
</BrowserRouter>
);
}
留言
avatar-img
梧笙 WuSheng 的沙龍
67會員
57內容數
⛰️ 梧笙,意即「吾生」,我是一個平凡的理工宅男。 生活離不開 Code 與 Game,這裡主要紀錄與分享: 📖 學習筆記|紀錄我學習過的電腦技能與知識。 💻 科技新知|整理實用工具與科技領域的資訊。 🎮 電玩娛樂|聊聊遊戲動漫與實況直播的話題。 目前更新頻率不固定,有興趣歡迎追蹤。
2026/05/06
React 動態路由就是讓網頁根據網址中的「變動部分」,自動顯示對應內容的機制。動態路由概念,路由參數:網址中用 : 開頭的變動部分,例如 :id,它會被替換成實際的值,像是 1、42、hello 等。
2026/05/06
React 動態路由就是讓網頁根據網址中的「變動部分」,自動顯示對應內容的機制。動態路由概念,路由參數:網址中用 : 開頭的變動部分,例如 :id,它會被替換成實際的值,像是 1、42、hello 等。
2026/05/05
Async/Await 是用來處理非同步操作的語法,讓你可以用「一行接一行」的方式撰寫需要等待的程式碼,例如 fetch。
2026/05/05
Async/Await 是用來處理非同步操作的語法,讓你可以用「一行接一行」的方式撰寫需要等待的程式碼,例如 fetch。
2026/05/05
Fetching 就是透過瀏覽器提供的 fetch API,向遠端伺服器發送請求並取得資料。Fetching 概念,useEffect:告訴 React「當元件出現在畫面上時,幫我執行這段工作」,通常用來發送資料請求。
2026/05/05
Fetching 就是透過瀏覽器提供的 fetch API,向遠端伺服器發送請求並取得資料。Fetching 概念,useEffect:告訴 React「當元件出現在畫面上時,幫我執行這段工作」,通常用來發送資料請求。
看更多
你可能也想看
Thumbnail
這集介紹Next Image Module模組和CSS3如何定位在Next.js Framework
Thumbnail
這集介紹Next Image Module模組和CSS3如何定位在Next.js Framework
Thumbnail
這篇文章深入淺出地解釋 JavaScript 中表達式 (expression) 與陳述式 (statement) 的差異,並以 React 中 JSX 的應用為例,說明為何大括號 {} 內只能放入表達式。文章以類比人類語言的句子結構來幫助理解,並提供相關參考資料連結。
Thumbnail
這篇文章深入淺出地解釋 JavaScript 中表達式 (expression) 與陳述式 (statement) 的差異,並以 React 中 JSX 的應用為例,說明為何大括號 {} 內只能放入表達式。文章以類比人類語言的句子結構來幫助理解,並提供相關參考資料連結。
Thumbnail
React.js 是一個熱門的library,JayLin今天講解React核心概念以及利用一個小案例概括理論部分
Thumbnail
React.js 是一個熱門的library,JayLin今天講解React核心概念以及利用一個小案例概括理論部分
Thumbnail
當時間變少之後,看戲反而變得更加重要——這是在成為母親之後,我第一次誠實地面對這一件事:我沒有那麼多的晚上,可以任性地留給自己了。看戲不再只是「今天有沒有空」,而是牽動整個週末的結構,誰應該照顧孩子,我該在什麼時間回到家,隔天還有沒有精神帶小孩⋯⋯於是,我不得不學會一件以前並不擅長的事:挑選。
Thumbnail
當時間變少之後,看戲反而變得更加重要——這是在成為母親之後,我第一次誠實地面對這一件事:我沒有那麼多的晚上,可以任性地留給自己了。看戲不再只是「今天有沒有空」,而是牽動整個週末的結構,誰應該照顧孩子,我該在什麼時間回到家,隔天還有沒有精神帶小孩⋯⋯於是,我不得不學會一件以前並不擅長的事:挑選。
Thumbnail
見諸參與鄧伯宸口述,鄧湘庭於〈那個大霧的時代〉記述父親回憶,鄧伯宸因故遭受牽連,而案件核心的三人,在鄧伯宸記憶裡:「成立了成大共產黨,他們製作了五星徽章,印刷共產黨宣言——刻鋼板的——他們收集中共空飄的傳單,以及中國共產黨中央委員會有關文化大革命決議文的英文打字稿,另外還有手槍子彈十發。」
Thumbnail
見諸參與鄧伯宸口述,鄧湘庭於〈那個大霧的時代〉記述父親回憶,鄧伯宸因故遭受牽連,而案件核心的三人,在鄧伯宸記憶裡:「成立了成大共產黨,他們製作了五星徽章,印刷共產黨宣言——刻鋼板的——他們收集中共空飄的傳單,以及中國共產黨中央委員會有關文化大革命決議文的英文打字稿,另外還有手槍子彈十發。」
Thumbnail
當代名導基里爾.賽勒布倫尼科夫身兼電影、劇場與歌劇導演,其作品流動著強烈的反叛與詩意。在俄烏戰爭爆發後,他持續以創作回應專制體制的壓迫。《傳奇:帕拉贊諾夫的十段殘篇》致敬蘇聯電影大師帕拉贊諾夫。本文作者透過媒介本質的分析,解構賽勒布倫尼科夫如何利用影劇雙棲的特質,在荒謬世道中尋找藝術的「生存之道」。
Thumbnail
當代名導基里爾.賽勒布倫尼科夫身兼電影、劇場與歌劇導演,其作品流動著強烈的反叛與詩意。在俄烏戰爭爆發後,他持續以創作回應專制體制的壓迫。《傳奇:帕拉贊諾夫的十段殘篇》致敬蘇聯電影大師帕拉贊諾夫。本文作者透過媒介本質的分析,解構賽勒布倫尼科夫如何利用影劇雙棲的特質,在荒謬世道中尋找藝術的「生存之道」。
Thumbnail
5 月,方格創作島正式開島。這是一趟 28 天的創作旅程。活動期間,每週都會有新的任務地圖與陪跑計畫,從最簡單的帳號使用、沙龍建立,到帶著你從一句話、一張照片開始,一步一步找到屬於自己的創作節奏。不需要長篇大論,不需要完美的文筆,只需要帶上你今天的日常,就可以出發。征服創作島,抱回靈感與大獎!
Thumbnail
5 月,方格創作島正式開島。這是一趟 28 天的創作旅程。活動期間,每週都會有新的任務地圖與陪跑計畫,從最簡單的帳號使用、沙龍建立,到帶著你從一句話、一張照片開始,一步一步找到屬於自己的創作節奏。不需要長篇大論,不需要完美的文筆,只需要帶上你今天的日常,就可以出發。征服創作島,抱回靈感與大獎!
Thumbnail
本系列文章將循序漸進地介紹 JavaScript 的核心概念,從基礎語法到進階應用,例如非同步程式設計和 React 基礎。內容淺顯易懂,並使用生活化的比喻幫助讀者理解,搭配程式碼範例,適合 JavaScript 初學者學習。
Thumbnail
本系列文章將循序漸進地介紹 JavaScript 的核心概念,從基礎語法到進階應用,例如非同步程式設計和 React 基礎。內容淺顯易懂,並使用生活化的比喻幫助讀者理解,搭配程式碼範例,適合 JavaScript 初學者學習。
Thumbnail
這集跟大家初步介紹Next.js和如何安裝與設置最後製作一個作品集(Portfolio) 如果對設計有興趣的朋友們可以看以下連結文章來學習Figma設計軟件 https://vocus.cc/article/645c733dfd89780001ffe890
Thumbnail
這集跟大家初步介紹Next.js和如何安裝與設置最後製作一個作品集(Portfolio) 如果對設計有興趣的朋友們可以看以下連結文章來學習Figma設計軟件 https://vocus.cc/article/645c733dfd89780001ffe890
Thumbnail
動態導覽列為增加使用者經驗UX,要如何在Tailwind CSS上實現呢?這次JayLin來帶大家做一個動態導覽列(Animation Navigation)
Thumbnail
動態導覽列為增加使用者經驗UX,要如何在Tailwind CSS上實現呢?這次JayLin來帶大家做一個動態導覽列(Animation Navigation)
Thumbnail
Todo App是一個很好學習程式語言的專案開始,JayLin來帶大家手把手用TypeScript | React | TailwildCSS 來做一個小專案
Thumbnail
Todo App是一個很好學習程式語言的專案開始,JayLin來帶大家手把手用TypeScript | React | TailwildCSS 來做一個小專案
Thumbnail
useEffect 是 React 的一個 Hook,它告訴 React 在以下情況下執行某些代碼。 透過本章的學習,你將能夠 熟練使用 useEffect() 處理 React 副作用,並掌握 最佳實務,確保 React 應用運行順暢、效能最佳!
Thumbnail
useEffect 是 React 的一個 Hook,它告訴 React 在以下情況下執行某些代碼。 透過本章的學習,你將能夠 熟練使用 useEffect() 處理 React 副作用,並掌握 最佳實務,確保 React 應用運行順暢、效能最佳!
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News