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

相关推荐
Liu.77418 分钟前
vue3使用vue3-print-nb打印
前端·javascript·vue.js
松涛和鸣1 小时前
Linux Makefile : From Basic Syntax to Multi-File Project Compilation
linux·运维·服务器·前端·windows·哈希算法
dly_blog1 小时前
Vue 逻辑复用的多种方案对比!
前端·javascript·vue.js
做cv的小昊1 小时前
【TJU】信息检索与分析课程笔记和练习(1)认识文献
经验分享·笔记·学习·搜索引擎·全文检索
万少2 小时前
HarmonyOS6 接入分享,原来也是三分钟的事情
前端·harmonyos
烛阴2 小时前
C# 正则表达式:量词与锚点——从“.*”到精确匹配
前端·正则表达式·c#
读创商闻2 小时前
崇明岛西滩湿地:离都市最近的候鸟观测笔记
笔记
wyzqhhhh2 小时前
京东啊啊啊啊啊
开发语言·前端·javascript
JIngJaneIL2 小时前
基于java+ vue助农电商系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
蒙奇D索大2 小时前
【11408学习记录】考研英语长难句拆解三步法:三步拆解2020年真题,攻克阅读难点
笔记·学习·考研·改行学it