ReactRouter快速梳理

快速开始

  1. 创建项目并安装所有依赖

    npx create-react-app react-router-pro
    
  2. 安装最新的reactrouter包

    npm i react-router-dom
    
  3. 启动项目

    npm run start
    

搭建路由(index.js)

//index.js项目的入口 从这里开始运行

//react必要的两个核心包
import React from 'react';
import ReactDOM from 'react-dom/client';
//导入项目的根组件
import App from './App';

import {createBrowserRouter,RouterProvider} from 'react-router-dom'
		//路由配置
const router = createBrowserRouter([   
    {
        path:'/login',
        element: <div>我是登录页</div>
    },
    {
        path:'/article',
        element: <div>我是文档页</div>
    },
])
//把app根组件渲染到id为root的节点上
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(
    <React.StrictMode>
  		/* 路由绑定 */}
        <RouterProvider router={router}></RouterProvider>
    </React.StrictMode>
    );

抽象路由模块

创建两个文件夹 page和router

page文件夹下的login文件夹下的login.js(article同理)

const Login = () =>{
    return <div>我是登录页</div>
}
export default Login

在router下的index.js中配置路由并导出

import Login from "../page/Login";
import Article from "../page/Article";
import { createBrowserRouter } from "react-router-dom";
//配置
const router = createBrowserRouter([
    {
        path:'/login',
        element:<Login />
    },
    {
        path:'/article',
        element:<Article />
    },
])
export default router

应用入口文件index.js渲染RouterProvider

import React from 'react';
import ReactDOM from 'react-dom/client';
import App from './App';
import {RouterProvider} from 'react-router-dom'

//导入路由router
import router from './router'
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(
    <React.StrictMode>
        {/* 路由绑定 */}
        <RouterProvider router={router}></RouterProvider>
    </React.StrictMode>
    );

路由导航跳转

路由系统中的多个路由之间需要进行路由跳转,并且在跳转的同时有可能需要传递参数通信

声明式导航

通过在模版中通过’‘’'组件描述出要跳转到哪里去,常用在点击菜单的跳转操作

import { Link } from 'react-router-dom'
const Login = () =>{
    return (
    <div>
        我是登录页
        <Link to="/article">跳转到文章页</Link>
    </div>
    )
}
export default Login

编程式导航

指通过useNavigate钩子得到导航方法,然后通过调用方法以命令式的形式进行路由跳转,比如想在登录请求完毕之后跳转就可以选择这种方式。

import { useNavigate } from "react-router-dom"
const Login = () =>{
    const navigate = useNavigate()
    return (
    <div>
        我是登录页
        <button onClick={() => navigate('/article')}>跳转到文档</button>
    </div>
    )
}
export default Login

路由导航传参

searchParams传参

login文件夹下的index.js

import { useNavigate } from "react-router-dom"
import { Link } from 'react-router-dom'
const Login = () =>{
    const navigate = useNavigate()
    return (
    <div>
        我是登录页
        <button onClick={() => navigate('/article?id=1001&name=Jack')}>serachparams传参跳转到文章页面</button>
    </div>
    )
}
export default Login

article文件夹下的index.js(接收参数)

import { useSearchParams } from "react-router-dom"
const Article = () =>{
    const [params] =  useSearchParams()      //接收参数
    const id = params.get('id')
    const name = params.get('name')
    return <div>我是文章页{id}-{name}</div>
}
export default Article

params传参

login文件夹下的index.js

import { useNavigate } from "react-router-dom"
import { Link } from 'react-router-dom'
const Login = () =>{
    const navigate = useNavigate()
    return (
    <div>
        我是登录页
        <Link to="/article">跳转到文章页</Link>
        <button onClick={() => navigate('/article/1001/jack')}>Params传参跳转到文章页面</button>
    </div>
    )
}
export default Login

修改路由router文件夹下的index.js

    {
        path:'/article/:id/:name',  //在对应的router位置拼接参数占位符
        element:<Article />
    }

article文件夹下的index.js(接收参数)

import { useParams } from "react-router-dom"
const Article = () =>{
    const params = useParams()
    const id = params.id
    const name = params.name
    return <div>我是文章页{id}-{name}</div>
}
export default Article

嵌套路由

在一级路由中又内嵌了其他路由,这种关系就叫做嵌套路由,嵌套至一级路由内的路由为二级路由

  1. 使用children属性配置路由嵌套关系
  2. 使用组件配置二级路由渲染位置

router文件夹下的index.js

import Layout from "../page/Layout";
import Login from "../page/Login";
import Article from "../page/Article";
import About from "../page/About";
import Board from "../page/Board";
import { createBrowserRouter } from "react-router-dom";
//配置
const router = createBrowserRouter([
    {
        path:'/',            //一级路由
        element:<Layout />,
        children: [           //二级路由
            {
                path:'board',
                element:<Board />
            },
            {
                path:'about',
                element:<About />
            }
        ]
    },
    {
        path:'/login',
        element:<Login />
    },
    {
        path:'/article/:id',
        element:<Article />
    },

])
export default router

Layout文件夹下的index.js

import { Link, Outlet } from "react-router-dom"
const Layout = ()=>{
    return (
        <div>
            我是一级路由layout组件
            <Link to="/board">面板</Link>
            <Link to="/about">关于</Link>
      
            {/* 配置二级路由出口 */}
            <Outlet />
        </div>
    )
}
export default Layout

默认二级路由配置

当访问的一级路由时,默认的二级路由组件可以得到渲染,只需要在二级路由的位置去掉path,设置index属性为true

{
        path:'/',            
        element:<Layout />,
        children: [
            {
                path:'board',
                element:<Board />
            },
            {
                index: true,
                element:<About />
            }
        ]
    },

404路由配置

当浏览器找不到对应的path,为了用户体验,可以使用404兜底组件进行渲染

  1. 准备一个NotFound组件
  2. 在路由表数组的末尾,以*号作为路由path配置路由
const NotFound = () =>{
  return <div>页面跑到月球了 </div>
}
export default NotFound
{
  path:'*',
  element: <NotFound />
}

两种路由模式

history 模式 和 hash模式

ReactRouter分别由createBrowerRouter和createHashRouter函数负责创建

路由模式URL表现底层原理是否需要后端支持
historyurl/loginhistory对象+pushState事件需要
hashurl/#/login监听hashChange事件不需要
import { createBrowserRouter ,createHashRouter} from "react-router-dom";

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/888181.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

STM32 OLED

文章目录 前言一、OLED是什么&#xff1f;二、使用步骤1.复制 OLED.C .H文件1.1 遇到问题 2.统一风格3.主函数引用头文件3.1 oled.h 提供了什么函数 4.介绍显示一个字符的函数5. 显示十进制函数的讲解 三、使用注意事项3.1 配置符合自己的引脚3.2 花屏总结 前言 提示&#xff…

Elasticsearch要点简记

Elasticsearch要点简记 1、ES概述2、基础概念&#xff08;1&#xff09;索引、文档、字段&#xff08;2&#xff09;映射&#xff08;3&#xff09;DSL 3、架构原理4、索引字段的数据类型5、ES的三种分页方式&#xff08;1&#xff09;深度分页&#xff08;fromsize&#xff09…

ndb9300public-ndb2excel简介

1 引言 ndb9300是一个自己定义的机载导航数据库劳作&#xff08;不敢称为项目&#xff09;代号&#xff0c;其中3表示是第3种数据库。 多年前&#xff0c;对在役民航客机中的某型机载导航数据库的二进制文件进行分析&#xff0c;弄明白它的数据结构后做了几个工具&#xff0c…

【Flutter】- 核心语法

文章目录 知识回顾前言源码分析1. 有状态组件2. 无状态组件3. 组件生命周期4. 常用组件Container组件Text组件Image组件布局组件row colum stack expandedElevntButton按钮拓展知识总结知识回顾 【Flutter】- 基础语法 前言 Flutter是以组件化的思想构建客户端页面的,类似于…

算法与程序课程设计——观光铁路

观光铁路 一、任务 跳蚤国正在大力发展旅游业&#xff0c;每个城市都被打造成了旅游景点。 许多跳蚤想去其他城市旅游&#xff0c;但是由于跳得比较慢&#xff0c;它们的愿望难以实现。这时&#xff0c;小C听说有一种叫做火车的交通工具&#xff0c;在铁路上跑得很快&#x…

Kubernetes proxy 命令与集群资源交互中起的作用

关于 Kubernetes 中的 kubectl proxy 命令&#xff0c;理解它的作用有助于更深入地掌握 Kubernetes 如何管理集群内的资源&#xff0c;以及开发和调试时如何通过代理来简化交互。kubectl proxy 提供了一种安全且方便的方式来访问 Kubernetes API 服务器&#xff0c;尤其是在调试…

今日指数day8实战补充(上)

1.用户管理 1.多条件综合查询 1.1 多条件综合查询接口说明 1&#xff09;原型效果 2&#xff09;接口说明 功能描述&#xff1a;多条件综合查询用户分页信息&#xff0c;条件包含&#xff1a;分页信息 用户创建日期范围 服务路径&#xff1a;/api/users 服务方法&#xff1…

用Manim简单解释奇异值分解(SVD)和图像处理方面的应

一&#xff0c;介绍 奇异值分解&#xff08;SVD&#xff09;是一种重要的矩阵分解技术&#xff0c;在统计学、信号处理和机器学习等领域有广泛应用。对于任意给定的矩阵 A&#xff08;可以是任意形状的矩阵&#xff09;&#xff0c;SVD将其分解为三个特定的矩阵的乘积&#x…

idea2024设置中文

今天下载idea2024.2版本&#xff0c;发现已经装过中文插件&#xff0c;但是还是不显示中文&#xff0c;找了半天原来还需要设置中文选项 方案一 点击文件 -> 关闭项目 点击自定义 -> 选择语言 方案二 点击文件 -> 设置 外观与行为 -> 系统设置 -> 语言和地区…

LSTM时序预测 | Python实现LSTM长短期记忆神经网络时间序列预测

本文内容&#xff1a;Python实现LSTM长短期记忆神经网络时间序列预测&#xff0c;使用的数据集为AirPassengers 目录 数据集简介 1.步骤一 2.步骤二 3.步骤三 4.步骤四 数据集简介 AirPassengers 数据集的来源可以追溯到经典的统计和时间序列分析文献。原始数据集由 Box,…

增强分析:新时代的数据洞察工具

随着数据科学和人工智能的迅猛发展&#xff0c;分析数据的方式也发生了显著的变化。增强分析&#xff08;Augmented Analytics&#xff09;是近年来涌现出的新概念&#xff0c;它将人工智能&#xff08;AI&#xff09;、机器学习&#xff08;ML&#xff09;和自然语言处理&…

HarmonyOS NEXT - 表单录入组件封装(TextInput)

demo 地址: https://github.com/iotjin/JhHarmonyDemo 组件对应代码实现地址 代码不定时更新&#xff0c;请前往github查看最新代码 HarmonyOS NEXT - 表单录入组件封装&#xff08;TextInput&#xff09; 序JhFormInputCellJhFormSelectCellJhLoginTextField 序 鸿蒙next中有两…

java 的三种IO模型(BIO、NIO、AIO)

java 的三种IO模型&#xff08;BIO、NIO、AIO&#xff09; 一、BIO 阻塞式 IO&#xff08;Blocking IO&#xff09;1.1、BIO 工作机制1.2、BIO 实现单发单收1.3、BIO 实现多发多收1.4、BIO 实现客户端服务端多对一1.5、BIO 模式下的端口转发思想 二、NIO 同步非阻塞式 IO&#…

Android15车载音频之Virtualbox中QACT实时调试(八十八)

简介: CSDN博客专家、《Android系统多媒体进阶实战》一书作者 新书发布:《Android系统多媒体进阶实战》🚀 优质专栏: Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏: 多媒体系统工程师系列【原创干货持续更新中……】🚀 优质视频课程:AAOS车载系统+…

Pikachu- Over Permission-垂直越权

以admin 账号登陆&#xff0c;添加一个用户&#xff1b; 把添加用户的这个请求发送到 repeater&#xff1b; 退出admin&#xff0c;使用普通用户pikachu登陆&#xff1b; 只有查看权限&#xff1b; 使用pikachu 用户的认证信息&#xff0c;替换repeater处管理员创建用户请求的…

六、索引的数据结构

文章目录 1. 为什么使用索引2. 索引及其优缺点2.1 索引概述2.2 优点2.3 缺点3. InnoDB中索引的推演3.1 索引之前的查找3.1.1 在一个页中的查找3.1.2 在很多页中查找3.2 设计索引3.2.1 一个简单的索引设计方案3.2.2 InnoDB中的索引方案3.3 常见索引概念3.3.1 聚簇索引3.3.2 二级…

UDP协议【网络】

文章目录 UDP协议格式 UDP协议格式 16位源端口号&#xff1a;表示数据从哪里来。16位目的端口号&#xff1a;表示数据要到哪里去。16位UDP长度&#xff1a;表示整个数据报&#xff08;UDP首部UDP数据&#xff09;的长度。16位UDP检验和&#xff1a;如果UDP报文的检验和出错&…

centos一些常用命令

文章目录 查看磁盘信息使用 df 命令使用 du 命令 查看磁盘信息 使用 df 命令 df&#xff08;disk free&#xff09;命令用于显示文件系统的磁盘空间占用情况。 查看所有挂载点的磁盘使用情况&#xff1a; df -h选项说明&#xff1a; -h 参数表示以人类可读的格式&#xff0…

Windows下Jenkins控制台中文乱码

问题描述 问题情况如下图&#xff1a; 环境信息 Windows 11 家庭中文版java 21.0.4 2024-07-16 LTSJenkins 2.452.3 解决方法 增加系统JAVA_TOOL_OPTIONS&#xff0c;并设置值为-Dfile.encodingGBK。 打开设置方法&#xff1a;桌面上右键点击“此电脑”图标&#xff0c;选…

【黑马点评】使用RabbitMQ实现消息队列——3.使用Jmeter压力测试,导入批量token,测试异步秒杀下单

3 批量获取用户token&#xff0c;使用jmeter压力测试 3 批量获取用户token&#xff0c;使用jmeter压力测试3.1 需求3.2 实现3.2.1 环境配置3.2.2 修改登录接口UserController和实现类3.2.3 测试类 3.3 使用jmeter进行测试3.4 测试结果3.5 将用户登录逻辑修改回去 3 批量获取用户…