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

相关推荐
鱼锦0.01 小时前
在vue2中主页面怎么给子页面传递数据
前端·javascript·html
!win !5 小时前
前端跨标签页通信方案(下)
前端·javascript
f***45325 小时前
基于SpringBoot和PostGIS的各省与地级市空间距离分析
android·前端·后端
编码追梦人5 小时前
从 “手忙脚乱“ 到 “行云流水“:华为云 DevUI 与 MateChat 如何让前端开发飞起来
前端·华为云
用户47949283569156 小时前
TypeScript 简史:它是怎么拯救我的烂代码的
javascript·typescript
S***H2836 小时前
前端动画实现经验,性能优化与兼容性
前端
用户47949283569156 小时前
只有前端 Leader 才会告诉你:那些年踩过的模块加载失败的坑(二)
javascript
xw56 小时前
前端跨标签页通信方案(下)
前端·javascript
zzlyx997 小时前
IoTSharp前端VUE采用npm run build编译提示require() of ES Module 出错
前端·vue.js·npm
全栈技术负责人7 小时前
拒绝“无法复现”:前端全链路日志排查实战手册
前端·全链路·问题排查思路