当前位置:首页 > React

react如何使用路由

2026-01-14 09:57:19React

使用 React Router 的基本方法

React Router 是 React 应用中实现路由功能的核心库。以下是基本使用方法:

安装 React Router 依赖包:

npm install react-router-dom

在应用中引入必要的组件:

import { BrowserRouter as Router, Route, Routes, Link } from 'react-router-dom';

配置基本路由结构

创建路由配置的最简示例:

function App() {
  return (
    <Router>
      <nav>
        <Link to="/">Home</Link>
        <Link to="/about">About</Link>
      </nav>

      <Routes>
        <Route path="/" element={<Home />} />
        <Route path="/about" element={<About />} />
      </Routes>
    </Router>
  );
}

动态路由参数处理

使用冒号语法定义动态路由:

<Route path="/users/:userId" element={<UserProfile />} />

在组件中获取路由参数:

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

function UserProfile() {
  const { userId } = useParams();
  return <div>User ID: {userId}</div>;
}

嵌套路由实现

通过嵌套 Route 组件实现层级路由:

<Route path="/products" element={<Products />}>
  <Route path=":productId" element={<ProductDetail />} />
  <Route path="new" element={<NewProduct />} />
</Route>

在父组件中使用 Outlet 渲染子路由:

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

function Products() {
  return (
    <div>
      <h2>Products</h2>
      <Outlet />
    </div>
  );
}

编程式导航

使用 useNavigate 钩子进行编程式导航:

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

function LoginButton() {
  const navigate = useNavigate();

  const handleLogin = () => {
    navigate('/dashboard');
  };

  return <button onClick={handleLogin}>Login</button>;
}

路由守卫实现

通过自定义包装组件实现路由守卫:

function PrivateRoute({ element }) {
  const isAuthenticated = checkAuth();
  return isAuthenticated ? element : <Navigate to="/login" />;
}

// 使用方式
<Route path="/dashboard" element={<PrivateRoute element={<Dashboard />} />} />

路由懒加载

使用 React.lazy 和 Suspense 实现懒加载:

react如何使用路由

const About = React.lazy(() => import('./About'));

function App() {
  return (
    <Suspense fallback={<div>Loading...</div>}>
      <Routes>
        <Route path="/about" element={<About />} />
      </Routes>
    </Suspense>
  );
}

分享给朋友:

相关文章

vue路由实现登录

vue路由实现登录

路由守卫实现登录验证 在Vue项目中,可以通过路由守卫(Navigation Guards)来实现登录验证逻辑。路由守卫能在路由跳转前、跳转后或跳转时进行拦截处理。 安装路由依赖 npm inst…

vue路由怎么实现

vue路由怎么实现

Vue 路由实现方法 Vue 路由通常通过 vue-router 库实现,以下是具体实现步骤: 安装 vue-router 在项目中运行以下命令安装 vue-router: npm install…

hashrouter如何使用react

hashrouter如何使用react

使用 HashRouter 在 React 中的方法 安装 react-router-dom 确保项目中已安装 react-router-dom,若未安装,可通过以下命令安装: npm inst…

react如何使用函数

react如何使用函数

使用函数组件的基本语法 在React中,函数组件是通过JavaScript函数定义的组件。函数接收props作为参数,并返回React元素。 function Welcome(props) {…

php 实现路由

php 实现路由

PHP 实现路由的方法 在 PHP 中实现路由功能可以通过多种方式完成,以下是几种常见的实现方法: 使用原生 PHP 实现简单路由 通过解析 URL 并匹配对应的处理逻辑,可以实现基本的路由功能。以…

vue script 实现路由

vue script 实现路由

使用 Vue Router 实现路由 在 Vue 项目中,可以通过 Vue Router 实现路由功能。以下是具体实现步骤: 安装 Vue Router npm install vue-route…