Router

收藏628

阅读3544

更新时间2025-08-20

创建 React App 不包括页面路由。

React 路由是最流行的解决方案。


添加 React 路由

要在您的应用程序中添加 React 路由,请从应用程序的根目录在终端中运行:

npm i -D react-router-dom

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

如果您是从 v5 升级,则需要使用 @latest 标志:

npm i -D react-router-dom@latest

文件夹结构

要创建具有多个页面路由的应用程序,我们首先从文件结构开始。

src 文件夹中,我们将创建一个名为 pages 的文件夹,其中包含几个文件: p>

src\pages\:

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

每个文件都将包含一个非常基本的 React 组件。


基本用法

现在我们将在 index.js 文件中使用我们的路由器。

实例

使用 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> 可以嵌套。 第一个<Route>的路径是/,渲染Layout组件。

嵌套的 <Route> 继承并添加到父路由。 所以 blogs 路径与父路径合并成为 /blogs

Home 组件路由没有路径,但有一个 index 属性。 将这条路由指定为父路由的默认路由,即 /

path 设置为 * 将充当任何未定义 URL 的全部内容。 这对于 404 错误页面非常有用。


页面/组件

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;

相关

视频

RELATED VIDEOS

更多

免费

Web前端开发极速入门
初级 Web前端开发极速入门

220622次学习

收藏

免费

前端入门_HTML5
初级 前端入门_HTML5

619062次学习

收藏

免费

30分钟学会网站布局
初级 30分钟学会网站布局

239149次学习

收藏

免费

CSS视频教程-玉女心经版
初级 CSS视频教程-玉女心经版

394761次学习

收藏

免费

独孤九贱(1)_HTML5视频教程

免费

独孤九贱(6)_jQuery视频教程

免费

独孤九贱(7)_Bootstrap视频教程

免费

独孤九贱(2)_CSS视频教程
初级 独孤九贱(2)_CSS视频教程

230705次学习

收藏

科技资讯

更多

精选课程

更多
前端入门_HTML5
前端入门_HTML5

共29课时

62万人学习

CSS视频教程-玉女心经版
CSS视频教程-玉女心经版

共25课时

39.5万人学习

JavaScript极速入门_玉女心经系列
JavaScript极速入门_玉女心经系列

共43课时

71.3万人学习

独孤九贱(1)_HTML5视频教程
独孤九贱(1)_HTML5视频教程

共25课时

61.9万人学习

独孤九贱(2)_CSS视频教程
独孤九贱(2)_CSS视频教程

共22课时

23.1万人学习

独孤九贱(3)_JavaScript视频教程
独孤九贱(3)_JavaScript视频教程

共28课时

34.1万人学习

独孤九贱(4)_PHP视频教程
独孤九贱(4)_PHP视频教程

共89课时

125.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号