React 路由

简介: 10月更文挑战第11天

React 路由通常使用 react-router 库来实现,它是一个功能强大的库,用于在 React 应用程序中实现客户端路由。以下是关于如何在 React 中使用 React Router 的详细说明:

安装 React Router

首先,你需要安装 react-router-dom 包,这是用于在浏览器环境中实现路由的包。

npm install react-router-dom

基本用法

以下是使用 React Router 设置基本路由的步骤和示例代码。

1. 创建基础路由组件

首先,创建一些简单的组件,它们将被路由渲染。

实例

import React from 'react';


const Home = () => {

 return <h2>Home</h2>;

};


export default Home;


// About.js

import React from 'react';


const About = () => {

 return <h2>About</h2>;

};


export default About;


// Contact.js

import React from 'react';


const Contact = () => {

 return <h2>Contact</h2>;

};


export default Contact;

2. 设置路由

在你的主应用组件中,使用 react-router-dom 的组件来设置路由。

实例

import React from 'react';

import ReactDOM from 'react-dom/client';

import {

 BrowserRouter as Router,

 Routes,

 Route,

 Link

} from 'react-router-dom';


import Home from './Home';

import About from './About';

import Contact from './Contact';


const App = () => {

 return (

   <Router>

     <div>

       <nav>

         <ul>

           <li>

             <Link to="/">Home</Link>

           </li>

           <li>

             <Link to="/about">About</Link>

           </li>

           <li>

             <Link to="/contact">Contact</Link>

           </li>

         </ul>

       </nav>

       <Routes>

         <Route path="/" element={<Home />} />

         <Route path="/about" element={<About />} />

         <Route path="/contact" element={<Contact />} />

       </Routes>

     </div>

   </Router>

 );

};


const root = ReactDOM.createRoot(document.getElementById('root'));

root.render(<App />);

嵌套路由

React Router 允许你创建嵌套路由,这样可以在一个组件内渲染更多的路由。

实例

// Dashboard.js

import React from 'react';

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


const Dashboard = () => {

 return (

   <div>

     <h2>Dashboard</h2>

     <nav>

       <ul>

         <li>

           <Link to="profile">Profile</Link>

         </li>

         <li>

           <Link to="settings">Settings</Link>

         </li>

       </ul>

     </nav>

     <Outlet />

   </div>

 );

};


export default Dashboard;

实例

// Profile.js

import React from 'react';


const Profile = () => {

 return <h2>Profile</h2>;

};


export default Profile;

实例

// Settings.js

import React from 'react';


const Settings = () => {

 return <h2>Settings</h2>;

};


export default Settings;

在主应用组件中设置嵌套路由:

实例

import React from 'react';

import ReactDOM from 'react-dom/client';

import {

 BrowserRouter as Router,

 Routes,

 Route,

 Link

} from 'react-router-dom';


import Home from './Home';

import About from './About';

import Contact from './Contact';

import Dashboard from './Dashboard';

import Profile from './Profile';

import Settings from './Settings';


const App = () => {

 return (

   <Router>

     <div>

       <nav>

         <ul>

           <li>

             <Link to="/">Home</Link>

           </li>

           <li>

             <Link to="/about">About</Link>

           </li>

           <li>

             <Link to="/contact">Contact</Link>

           </li>

           <li>

             <Link to="/dashboard">Dashboard</Link>

           </li>

         </ul>

       </nav>

       <Routes>

         <Route path="/" element={<Home />} />

         <Route path="/about" element={<About />} />

         <Route path="/contact" element={<Contact />} />

         <Route path="/dashboard" element={<Dashboard />}>

           <Route path="profile" element={<Profile />} />

           <Route path="settings" element={<Settings />} />

         </Route>

       </Routes>

     </div>

   </Router>

 );

};


const root = ReactDOM.createRoot(document.getElementById('root'));

root.render(<App />);

动态路由

可以在路径中包含动态参数。

实例

// User.js

import React from 'react';

import { useParams } from 'react-router-dom';


const User = () => {

 const { userId } = useParams();

 return <h2>User ID: {userId}</h2>;

};


export default User;

在主应用组件中设置动态路由:

实例

import React from 'react';

import ReactDOM from 'react-dom/client';

import {

 BrowserRouter as Router,

 Routes,

 Route,

 Link

} from 'react-router-dom';


import Home from './Home';

import About from './About';

import Contact from './Contact';

import Dashboard from './Dashboard';

import Profile from './Profile';

import Settings from './Settings';

import User from './User';


const App = () => {

 return (

   <Router>

     <div>

       <nav>

         <ul>

           <li>

             <Link to="/">Home</Link>

           </li>

           <li>

             <Link to="/about">About</Link>

           </li>

           <li>

             <Link to="/contact">Contact</Link>

           </li>

           <li>

             <Link to="/dashboard">Dashboard</Link>

           </li>

           <li>

             <Link to="/user/1">User 1</Link>

           </li>

           <li>

             <Link to="/user/2">User 2</Link>

           </li>

         </ul>

       </nav>

       <Routes>

         <Route path="/" element={<Home />} />

         <Route path="/about" element={<About />} />

         <Route path="/contact" element={<Contact />} />

         <Route path="/dashboard" element={<Dashboard />}>

           <Route path="profile" element={<Profile />} />

           <Route path="settings" element={<Settings />} />

         </Route>

         <Route path="/user/:userId" element={<User />} />

       </Routes>

     </div>

   </Router>

 );

};


const root = ReactDOM.createRoot(document.getElementById('root'));

root.render(<App />);

404 页面

可以使用 React Router 提供的 Navigate 组件来实现 404 页面重定向。

实例

import React from 'react';

import ReactDOM from 'react-dom/client';

import {

 BrowserRouter as Router,

 Routes,

 Route,

 Link,

 Navigate

} from 'react-router-dom';


import Home from './Home';

import About from './About';

import Contact from './Contact';

import Dashboard from './Dashboard';

import Profile from './Profile';

import Settings from './Settings';

import User from './User';


const NotFound = () => {

 return <h2>404 Page Not Found</h2>;

};


const App = () => {

 return (

   <Router>

     <div>

       <nav>

         <ul>

           <li>

             <Link to="/">Home</Link>

           </li>

           <li>

             <Link to="/about">About</Link>

           </li>

           <li>

             <Link to="/contact">Contact</Link>

           </li>

           <li>

             <Link to="/dashboard">Dashboard</Link>

           </li>

           <li>

             <Link to="/user/1">User 1</Link>

           </li>

           <li>

             <Link to="/user/2">User 2</Link>

           </li>

         </ul>

       </nav>

       <Routes>

         <Route path="/" element={<Home />} />

         <Route path="/about" element={<About />} />

         <Route path="/contact" element={<Contact />} />

         <Route path="/dashboard" element={<Dashboard />}>

           <Route path="profile" element={<Profile />} />

           <Route path="settings" element={<Settings />} />

         </Route>

         <Route path="/user/:userId" element={<User />} />

         <Route path="*" element={<Navigate to="/" replace />} />

       </Routes>

     </div>

   </Router>

 );

};


const root = ReactDOM.createRoot(document.getElementById('root'));

root.render(<App />);

小结

通过使用 React Router,你可以轻松地在 React 应用中实现路由功能,包括基本路由、嵌套路由、动态路由以及 404 页面等。通过这种方式,你可以创建一个功能强大且用户友好的单页应用程序 (SPA)。

目录
相关文章
|
1月前
|
前端开发 JavaScript
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
本文介绍了在React项目中实现路由懒加载的方法,使用React提供的`lazy`和`Suspense`来优化项目首次加载的速度。通过将路由组件改为懒加载的方式,可以显著减少初始包的大小,从而加快首次加载速度。文章还展示了如何使用`Suspense`组件包裹`Switch`来实现懒加载过程中的fallback效果,并提供了使用前后的加载时间对比,说明了懒加载对性能的提升作用。
94 2
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
|
2月前
|
移动开发 资源调度 前端开发
介绍React路由模式
【8月更文挑战第10天】介绍React路由模式
53 12
|
3天前
|
资源调度 前端开发 测试技术
React Router 路由管理
【10月更文挑战第10天】本文介绍了 React Router,一个在 React 应用中管理路由的强大工具。内容涵盖基本概念、安装与使用方法、常见问题及解决方案,如路由嵌套、动态路由和路由守卫等,并提供代码示例。通过学习本文,开发者可以更高效地使用 React Router,提升应用的导航体验和安全性。
56 19
|
14天前
|
前端开发 JavaScript 网络架构
实现动态路由与状态管理的SPA——使用React Router与Redux
【10月更文挑战第1天】实现动态路由与状态管理的SPA——使用React Router与Redux
26 1
|
1月前
|
前端开发 Python
React技术栈-React路由插件之自定义组件标签
关于React技术栈中React路由插件自定义组件标签的教程。
47 4
React技术栈-React路由插件之自定义组件标签
|
1月前
|
移动开发 前端开发 应用服务中间件
React两种路由模式的实现原理
React两种路由模式的实现原理
61 3
|
1月前
|
前端开发 程序员 API
React技术栈-React路由插件之react-router的基本使用
这篇博客介绍了React路由插件react-router的基本使用,包括其概念、API、以及如何通过实战案例在React应用中实现SPA(单页Web应用)的路由管理。
47 9
|
2月前
|
资源调度 前端开发 数据安全/隐私保护
react动态路由权限
【8月更文挑战第29天】 react动态路由权限
52 4
|
2月前
|
前端开发 JavaScript 算法
React Server Component 使用问题之想在路由切换时保持客户端状态,如何实现
React Server Component 使用问题之想在路由切换时保持客户端状态,如何实现
|
2月前
|
前端开发 JavaScript PHP
React Server Component 使用问题之路由的能力,如何实现
React Server Component 使用问题之路由的能力,如何实现