当前位置:首页 > 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>
  );
}

动态路由参数处理

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

react如何使用路由

<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 渲染子路由:

react如何使用路由

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 实现懒加载:

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 实现路由历史管理 在 Vue 中,路由历史管理通常通过 Vue Router 实现。Vue Router 提供了两种历史记录模式:hash 模式和 history 模式。以下是具体实现方法。…

vue路由实现

vue路由实现

Vue 路由实现方法 安装 Vue Router 在项目中安装 Vue Router 依赖包: npm install vue-router 配置路由 在 src 目录下创建 router/inde…

Vue中实现路由

Vue中实现路由

Vue 路由的实现方法 在 Vue 中实现路由通常使用 Vue Router 库。以下是具体的实现步骤: 安装 Vue Router 通过 npm 或 yarn 安装 Vue Router: n…

php 路由实现的

php 路由实现的

PHP 路由实现方法 基于原生 PHP 实现路由 创建一个简单的路由解析器,通过解析 URL 路径来调用对应的控制器或函数。 // 定义路由表 $routes = [ '/' => '…

vue如何实现路由

vue如何实现路由

路由基础配置 在Vue中实现路由通常使用Vue Router库。安装Vue Router后,在项目中创建路由配置文件(如router/index.js),定义路由路径与组件的映射关系: import…

vue实现路由拦截

vue实现路由拦截

路由拦截的实现方式 在Vue中,可以通过Vue Router的导航守卫(Navigation Guards)实现路由拦截。导航守卫分为全局守卫、路由独享守卫和组件内守卫三种类型。 全局前置守卫 使用…