当前位置:首页 > React

react如何定义路由

2026-02-12 00:32:59React

React 路由定义方法

在 React 中定义路由通常使用 react-router-dom 库,以下是几种常见的路由定义方式:

使用 BrowserRouter 和 Route

安装 react-router-dom

npm install react-router-dom

在应用中定义路由:

import { BrowserRouter as Router, Route, Routes } from 'react-router-dom';
import Home from './components/Home';
import About from './components/About';

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

嵌套路由定义

可以定义嵌套路由来创建层次结构:

<Routes>
  <Route path="/" element={<Layout />}>
    <Route index element={<Home />} />
    <Route path="about" element={<About />} />
    <Route path="contact" element={<Contact />} />
  </Route>
</Routes>

动态路由参数

使用冒号 : 定义动态路由参数:

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

在组件中获取参数:

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

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

404 路由处理

定义未匹配路由的默认页面:

<Routes>
  <Route path="/" element={<Home />} />
  <Route path="*" element={<NotFound />} />
</Routes>

编程式导航

使用 useNavigate 进行编程式导航:

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

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

  const handleClick = () => {
    navigate('/about');
  };

  return <button onClick={handleClick}>Go to About</button>;
}

路由守卫

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

function PrivateRoute({ element: Element, ...rest }) {
  const isAuthenticated = /* 验证逻辑 */;

  return isAuthenticated ? <Element {...rest} /> : <Navigate to="/login" />;
}

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

路由懒加载

使用 React.lazySuspense 实现懒加载:

react如何定义路由

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

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

以上方法涵盖了 React 路由的主要使用场景,可根据实际需求选择合适的方式。

标签: 路由定义
分享给朋友:

相关文章

vue实现户籍系统路由实现

vue实现户籍系统路由实现

户籍系统路由实现(Vue.js) 户籍系统通常需要管理居民信息、户籍变动、统计查询等功能模块。以下基于Vue Router的实现方案: 路由模块设计 在src/router/index.js中定义核…

vue实现路由管理

vue实现路由管理

Vue 路由管理实现方法 Vue 路由管理通常通过 vue-router 库实现,以下是具体实现方式: 安装 vue-router 通过 npm 或 yarn 安装最新版本: npm instal…

vue实现动态路由

vue实现动态路由

动态路由的实现方式 Vue中实现动态路由通常涉及前端和后端的协作,以下是几种常见的实现方式: 基于用户权限的路由控制 在用户登录后,根据其权限动态生成路由表。使用router.addRoutes方…

vue如何实现路由跳转

vue如何实现路由跳转

Vue 路由跳转的实现方法 Vue 中实现路由跳转主要通过 vue-router 库完成,以下是几种常见的路由跳转方式: 声明式导航(模板中使用 <router-link>) <…

vue实现路由懒加载

vue实现路由懒加载

路由懒加载的概念 路由懒加载是一种优化技术,通过将路由对应的组件拆分成独立的代码块,仅在访问该路由时才加载对应的组件代码。这种方式可以减少初始加载时间,提升应用性能。 使用动态导入语法 在Vue R…

vue路由跳转无法实现

vue路由跳转无法实现

路由配置问题 检查router/index.js中的路由配置是否正确。确保已定义目标路由且路径拼写无误。常见错误包括路径缺少斜杠或参数格式错误。 // 错误示例 { path: 'detail'…