選單
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

React Router


Create React App 不包含頁面路由。

React Router 是最流行的解決方案。


新增 React Router

要將 React Router 新增到你的應用程式中,請在應用程式的根目錄的終端中執行此命令:

npm i -D react-router-dom

注意:本教程使用 React Router v6。

如果你從 v5 升級,則需要使用 @latest 標誌

npm i -D react-router-dom@latest

資料夾結構

要建立一個具有多個頁面路由的應用程式,讓我們先從檔案結構開始。

src 資料夾內,我們將建立一個名為 pages 的資料夾,其中包含幾個檔案

src\pages\:

  • Layout.js
  • Home.js
  • Blogs.js
  • Contact.js
  • NoPage.js

每個檔案將包含一個非常基礎的 React 元件。


基本用法

現在我們將在 index.js 檔案中使用我們的 Router。

示例

使用 React Router 根據 URL 進行頁面路由

index.js:

import ReactDOM from "react-dom/client";
import { BrowserRouter, Routes, Route } from "react-router-dom";
import Layout from "./pages/Layout";
import Home from "./pages/Home";
import Blogs from "./pages/Blogs";
import Contact from "./pages/Contact";
import NoPage from "./pages/NoPage";

export default function App() {
  return (
    <BrowserRouter>
      <Routes>
        <Route path="/" element={<Layout />}>
          <Route index element={<Home />} />
          <Route path="blogs" element={<Blogs />} />
          <Route path="contact" element={<Contact />} />
          <Route path="*" element={<NoPage />} />
        </Route>
      </Routes>
    </BrowserRouter>
  );
}

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<App />);

執行示例 »

示例解釋

我們首先用 <BrowserRouter> 包裹我們的內容。

然後我們定義我們的 <Routes>。一個應用程式可以有多個 <Routes>。我們的基本示例只使用了一個。

<Route>s 可以巢狀。第一個 <Route> 的 path 是 /,它渲染 Layout 元件。

巢狀的 <Route>s 繼承並擴充套件了父路由。因此,blogs 的 path 與父路由結合,變成了 /blogs

Home 元件路由沒有 path,但有一個 index 屬性。這指定該路由是父路由(即 /)的預設路由。

path 設定為 * 將作為所有未定義 URL 的捕獲。這對於 404 錯誤頁面非常有用。


w3schools CERTIFIED . 2022

獲得認證!

完成 React 模組,完成練習,參加考試,並獲得 w3schools 認證!

$95 註冊

Pages / Components

Layout 元件包含 <Outlet><Link> 元素。

<Outlet> 渲染當前選中的路由。

<Link> 用於設定 URL 並跟蹤瀏覽歷史。

每當我們連結到內部路徑時,我們將使用 <Link> 而不是 <a href="">

“佈局路由”是一個共享元件,它在所有頁面上插入通用內容,例如導航選單。

Layout.js:

import { Outlet, Link } from "react-router-dom";

const Layout = () => {
  return (
    <>
      <nav>
        <ul>
          <li>
            <Link to="/">Home</Link>
          </li>
          <li>
            <Link to="/blogs">Blogs</Link>
          </li>
          <li>
            <Link to="/contact">Contact</Link>
          </li>
        </ul>
      </nav>

      <Outlet />
    </>
  )
};

export default Layout;

Home.js:

const Home = () => {
  return <h1>Home</h1>;
};

export default Home;

Blogs.js:

const Blogs = () => {
  return <h1>Blog Articles</h1>;
};

export default Blogs;

Contact.js:

const Contact = () => {
  return <h1>Contact Me</h1>;
};

export default Contact;

NoPage.js:

const NoPage = () => {
  return <h1>404</h1>;
};

export default NoPage;

×

聯絡銷售

如果您想將 W3Schools 服務用於教育機構、團隊或企業,請傳送電子郵件給我們
sales@w3schools.com

報告錯誤

如果您想報告錯誤,或想提出建議,請傳送電子郵件給我們
help@w3schools.com

W3Schools 經過最佳化,旨在方便學習和培訓。示例可能經過簡化,以提高閱讀和學習體驗。教程、參考資料和示例會不斷審查,以避免錯誤,但我們無法保證所有內容的完全正確性。使用 W3Schools 即表示您已閱讀並接受我們的使用條款Cookie 和隱私政策

版權所有 1999-2024 Refsnes Data。保留所有權利。W3Schools 由 W3.CSS 提供支援