react路由的使用

安装

javascript 复制代码
npm install react-router-dom

main.tsx中配置

javascript 复制代码
import React from 'react'
import { RouterProvider } from 'react-router-dom'
import ReactDOM from 'react-dom/client'
import App from './App.tsx'
import 'normalize.css'
import './index.css'

import router from './router/index.ts'

ReactDOM.createRoot(document.getElementById('root')!).render(
  <React.StrictMode>
    <RouterProvider router={ router } >
        <App />
    </RouterProvider>
  </React.StrictMode>,
)

router文件夹下index.ts路由表配置

javascript 复制代码
import { createBrowserRouter } from "react-router-dom";
import Layout from "@/pages/layout/Layout";
import Login from "@/pages/login/Login";
import Home from "@/pages/home/Home";


import type { Routes } from '@/types/router'

const routes:Array<Routes> = [
    {
        path:'/',
        //注意:这里C要大写
        Component:Layout,
        children:[
            //react-router路由表配置没有redirect重定向,故此在这里多加一项Home配置,同样能达 
            //到重定向效果
            {
                path:'/',
                Component:Home
            },
            {
                path:'/home',
                Component:Home
            }
        ]
    },
    {
        path:'/login',
        Component:Login
    }
]

const router = createBrowserRouter(routes)



export default router

App组件中使用

javascript 复制代码
import { Outlet } from 'react-router-dom'
import "./App.less";

function App() {

  return (
    <div className="app">  
       <Outlet />
    </div>
  );
}

export default App;

获取路由路径 useLocation

编程式导航 useNavigate

获取路由参数 useParams

相关推荐
写代码的皮筏艇9 分钟前
replace方法
前端·javascript
C澒9 分钟前
AI 生码 - API2CODE:接口智能匹配与 API 自动化生码实践
前端·低代码·ai编程
小茴香35312 分钟前
React学习笔记(一)
笔记·学习·react.js
idcu14 分钟前
Lyt.js AI:让前端开发进入智能生成时代
前端
idcu15 分钟前
深入 Lyt.js 编译器:.lyt 文件如何增强 HTML 模板能力
前端
即答侠15 分钟前
实时 AI copilot 的 4 级 fallback 设计:用户感知 0 中断,SLA 从 92% 拉到 99.6%
前端·人工智能
无心使然17 分钟前
Openlayers调用ArcGis地图服务之五 —— 要素识别(/identify)
前端·vue.js·数据可视化
Dxy123931021623 分钟前
HTML 如何设置 Div 阴影悬浮边框:从基础到进阶
前端·html·css3
好运的阿财24 分钟前
OpenClaw工具拆解之browser+agents_list
前端·人工智能·机器学习·开源软件·ai编程·openclaw·openclaw工具
JarvanMo31 分钟前
八个开源Flutter应用,让你成为更好的开发者
前端