React-router v6学生管理系统笔记

快速搭建服务器

我们使用的json-server

复制代码
初始化 npm init -y 
下载json-server
配置启动命令:"json:server":"json-server --watch db.json"
启动:npm run json:server

安装依赖

复制代码
npm i react-router-dom //安装路由
npm i axios  

React-route 路由总结

组件

  • BrowserRouter:整个路由以history模式开始,包裹跟组件

  • HashRouter: 整个前端路由以hash模式开始,包裹跟组件

    在index.js中
    import {BrowserRouter,HashRouter} from 'react-router-dom'
    <HashRouter>
    <App />
    </HashRouter>

  • Routes:主要是提供上下文环境

  • Route:在Route组件中,书写对应的路由,以及路由对应的组件
    path:匹配的路由
    element:匹配该路由要渲染的组件

  • Navigate:导航组件,类似于useNavigate的返回值函数

    import {Routes,Route,Navigate } from "react-router-dom"
    <Routes>
    <Route path="/home" element="<Home />"></Route>
    //重定向到home
    <Route path="/" element="<Navigate replace to="/home"></Navigate>"></Route>
    </Routes>

  • NavLink:类似于Link,最终会被渲染成a标签,他和link区别是有一个active的激活样式,一般做导航栏的跳转

    import {NavLink} from "react-router-dom"
    //跳转到home
    <NavLink to="/home"></NavLink>

  • Outlet:可以理解为 vue中的RouterView

hooks

  • useLocation: 获取location对象,我们可以获取state属性,这往往是其他路由跳转过来,传递额外的数据

    navigate('/home',{
    state:{
    name:'张三',
    type: 'delete'
    }
    })

    import {useLocation} from "react-router-dom"
    const location = useLocatioin()

  • useNavigate: 会返回一个函数,通过该函数做跳转

    import {useNavigate} from "react-router-dom"
    const navigate = useNavigate()
    navigate('/home')

  • useParams: 获取动态参数

    import {useParams} from "react-router-dom"
    const params= useParams()
    console.log("动态参数params:"+params)

  • useRoutes:通过函数hook形式定义

    import {useRoutes} from "react-router-dom"

    const routes = useRoutes([
    {
    path: '/home',
    element: <Home />
    },
    {
    path: '/about',
    element: <About/>
    children: [
    {
    path: 'tel',
    element: <Tel />
    }
    ]
    }
    ])
    return routes

相关推荐
明月_清风2 分钟前
自定义右键菜单:在项目里实现“选中文字即刻生成新提示”
前端·javascript
明月_清风3 分钟前
告别后端转换:高质量批量导出实战
前端·javascript
刘发财5 小时前
弃用html2pdf.js,这个html转pdf方案能力是它的几十倍
前端·javascript·github
牛奶7 小时前
2026年大模型怎么选?前端人实用对比
前端·人工智能·ai编程
牛奶7 小时前
前端人为什么要学AI?
前端·人工智能·ai编程
Kagol10 小时前
🎉OpenTiny NEXT-SDK 重磅发布:四步把你的前端应用变成智能应用!
前端·开源·agent
GIS之路11 小时前
ArcGIS Pro 中的 notebook 初识
前端
JavaGuide11 小时前
7 道 RAG 基础概念知识点/面试题总结
前端·后端
ssshooter11 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
格砸12 小时前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端