创建路由React router(使用react-router dom V6版本)

news2024/11/24 14:37:01

React路由

隔了很长一段时间,重新捡起来React学习。
发现React的路由从原来的 Switch改成了Routes。nice,nice,nice!!!!

刚开始接触确实还是有一点生疏的。之前的关于【传参】【js跳转】【跳转模式】【路由匹配】哪些还是有点印象。 在新的V6版本中,这些反而变的更加的简单了。

在这里插入图片描述


文章目录

  • React路由
  • 前言
  • 一、安装 react-router-dom (V6版本以上)
    • 命令行执行如下命令
  • 二、配置路由
    • 1. import导入组件如下
    • 2.导入展示组件(已经要提前写好自己展示的组件)
    • 3.在render中的配置如下
  • 三、路由的两种跳转方式(1.函数跳转 2.标签跳转)
    • 1. Link标签和useNavigate的使用(通过一个组件举例子)
    • 2. Link 和 useNavigate 的属性
      • 具体信息如下👇🔗
      • 配置如下图
  • 总结(本文未完结,后续会继续更新)


前言

本文大致介绍的的是如何在一个新的项目中自己搭建一个带路由的项目(要求:简单、易上手)

主要分为如下步骤:

1. 安装react的路由依赖
2. 配置路由(路由匹配、重定向)
3. 路由的跳转方式


一、安装 react-router-dom (V6版本以上)

命令行执行如下命令

//自动安装的就是 @6 版本以上的路由(无需关心)
 npm i react-router-dom (正确 🙆)

二、配置路由

1. import导入组件如下

//导入配置组件
import {
  BrowserRouter as Router, //路由组件(Vue中的router-view)
  Routes, //路由配置项 (Vue中的routes)
  Route, //路由对象 (Vue中的routes中的单个路由)
  Navigate, //重定向组件 (Vue中单个路由对像中的redirect属性)
} from "react-router-dom";

2.导入展示组件(已经要提前写好自己展示的组件)

//导入展示组件
import About from "./RouterComponent/About.jsx";
import AboutChildren from "./RouterComponent/AboutChildren/AboutChildren.jsx";
import Home from "./RouterComponent/Home.jsx";

3.在render中的配置如下

1. 这里的Route组件必须要用routes组件进行包裹!
2. Route组件中的属性 path (匹配的路由路径)
3. Route组件中的 element (同之前的component)
4. element属性必须是组件的形式,不能够是直接写 App 要写成 <App></App>
5.Navigate 组件主要是为了支持重定向,你们可以在使用的时候把这段代码注释,然后跳转到一个位置的路由下面,看看会发生什么情况!!!!


root.render(
  <Router>
    <Routes>
      <Route path="/" element={<App></App>}></Route>
      <Route path="/about" element={<About></About>}></Route>
      <Route
        path="/about/child1"
        element={<AboutChildren></AboutChildren>}></Route>
      <Route path="/home/:id" element={<Home></Home>}></Route>
     //这里注释的这部分主要是为了进行路由的重定向到App组件
     // <Route path="*" element={<Navigate to={"/"}></Navigate>}></Route>
    </Routes>
  </Router>
);

三、路由的两种跳转方式(1.函数跳转 2.标签跳转)

1. Link标签和useNavigate的使用(通过一个组件举例子)

//1.导入跳转的组件
import { Link, useNavigate } from "react-router-dom";

export default function About() {
//2. 创建对应的跳转实例
  const navigate = useNavigate();
  return (
    <div>
//3. button按钮通过事件触发跳转到 /home 的页面
      <button
        onClick={() => {
          navigate("/home");
        }}>
        跳转到home
      </button>
      <div className="margin20"></div>
 //4.通过导入的 Link标签的 to属性跳转到指定的  /about/child1 路径下
      <Link to="/about/child1">跳转到child1</Link>
    </div>
  );
}

2. Link 和 useNavigate 的属性

具体信息如下👇🔗

Link标签 介绍

useNavigate 介绍

配置如下图

在这里插入图片描述
在这里插入图片描述


总结(本文未完结,后续会继续更新)

提示:本文还需要完善,因为关于routes是JSON字段的配置形式还没更新。希望本文可以帮助大家轻松上手React路由

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

管理后台项目-06-用户管理角色管理模块

目录 1-路由信息搭建和api文件信息创建 2-用户管理模块 2.1-列表数据获取以及动态渲染 2.2-添加 | 修改 用户 2.3-删除-批量删除用户 2.4-分配角色 3-角色管理 3.1-修改角色 3.2-分配权限 1-路由信息搭建和api文件信息创建 我们先进行路由菜单的配置&#xff0c;在系统…

【测试开发】测试人的养成记,在这测试内卷乱世中突破测试开发...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 这几年&#xff0…

442. 数组中重复的数据|||41. 缺失的第一个正数|||485. 最大连续 1 的个数

442. 数组中重复的数据 题目 给你一个长度为 n 的整数数组 nums &#xff0c;其中 nums 的所有整数都在范围 [1, n] 内&#xff0c;且每个整数出现 一次 或 两次 。请你找出所有出现 两次 的整数&#xff0c;并以数组形式返回。 你必须设计并实现一个时间复杂度为 O(n) 且仅…

Python如何连接Mysql及基本操作

1.什么要做python连接mysql&#xff0c;一般是解决什么问题的 做自动化测试时候&#xff0c;注册了一个新用户&#xff0c;产生了多余的数据&#xff0c;下次同一个账号就无法注册了&#xff0c;这种情况怎么办呢&#xff1f;自动化测试都有数据准备和数据清理的操作&#xff…

KDJB-1200继电保护定值校验仪器

一、产品概述 KDJB-1200 微机继电保护校验仪是在参照电力部颁发的《微机型继电保护试验装置技术条件(讨论稿)》的基础上&#xff0c;听取用户意见&#xff0c;总结目前国内同类产品优缺点&#xff0c;充分使用现代微电子技术和器件实现的一种新型小型化微机继电保护测试仪。 采…

《C++ Primer Plus》(第6版)第18章编程练习

《C Primer Plus》&#xff08;第6版&#xff09;第18章编程练习 《C Primer Plus》&#xff08;第6版&#xff09;第18章编程练习1. 函数average_list()2.3. sum_value()4. 使用lambda重新编写程序清单16.15 《C Primer Plus》&#xff08;第6版&#xff09;第18章编程练习 1…

mysql进阶-查询优化-慢查询日志

文章目录 一、什么是慢查询日志二、慢查询日志能干什么2.1 性能分析和优化2.2 诊断和排查问题2.3 数据分析和探索 三、慢查询日志实战3.1 永久开启开启慢查询日志3.2 临时开启慢查询日志3.4 常用命令 四、如何分析慢查询日志五、优化慢查询语句五、总结 一、什么是慢查询日志 …

这场SIG组开放工作会议为何吸引了那么多人的关注?

【中国&#xff0c;上海&#xff0c;2023年4月20日-21日】openEuler Developer Day 2023在线上和线下同步举办。本次大会由开放原子开源基金会指导&#xff0c;中国软件行业协会、openEuler社区、边缘计算产业联盟共同主办&#xff0c;以“万涓汇流&#xff0c;奔涌向前”为主题…

数据仓库与数据库之间的区别与联系

文章目录 一、数据库与数据仓库的区别 1.1、区别 1.2、ACID内容 二、原子性&#xff08;Atomicity&#xff09; 三、持久性&#xff08;Durability&#xff09; 四、隔离性&#xff08;Isolation&#xff09; 1、锁机制 2、脏读、不可重复读和幻读 2、事务隔离级别 五…

权限提升:溢出漏洞.(普通权限 提升 管理员权限.)

权限提升&#xff1a;溢出漏洞 权限提升简称提权&#xff0c;由于操作系统都是多用户操作系统&#xff0c;用户之间都有权限控制&#xff0c;比如通过 Web 漏洞拿到的是 Web 进程的权限&#xff0c;往往 Web 服务都是以一个权限很低的账号启动的&#xff0c;因此通过 Webshell …

日增百亿数据,查询结果秒出, Apache Doris 在 360商业化的统一 OLAP 应用实践

导读&#xff1a; 360商业化为助力业务团队更好推进商业化增长&#xff0c;实时数仓共经历了三种模式的演进&#xff0c;分别是 Storm Druid MySQL 模式、Flink Druid TIDB 的模式 以及 Flink Doris 的模式&#xff0c;基于 Apache Doris 的新一代架构的成功落地使得 360商…

“不幸的是,你知道的太多了”

《平凡的世界》里有一段话是这么说的&#xff1a;“谁让你读了这么多书&#xff0c;又知道了双水村以外还有个大世界。 如果从小你就在这个天地里日出而作&#xff0c;日落而息&#xff0c;那你现在就会和众乡亲抱同一理想&#xff0c;经过几年的辛劳&#xff0c;像大哥一样娶…

PHP 实现会话Session信息共享

目录 解决方案也有很多种&#xff1a; 会话保持 会话复制 会话共享 环境准备 架构设计 SessionHandlerInterface接口 代码编写 总结 优化 前言&#xff1a; 小流量的网站中&#xff0c;我们往往只需要一台服务器就可以维持用户正常的访问以及相关的操作。 随着网站的…

Superset整合keycloak系统

本篇主要介绍superset如何整合单点登陆系统keycloak&#xff0c;现在网上的博客大部分都是失效了&#xff0c;这里我相当于更新一下&#xff0c;避免大家再走弯路 一、环境配置 Macos keycloak&#xff1a;18.0.0 superset&#xff1a;2.1.0 keycloak规定&#xff1a;每一…

原理这就是索引下推呀

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。 索引下推是之前面试的时候遇到的一个面试题&#xff0c;当时没有答上来&#xff0c;今天来学习一下。 介绍索引下推之前先看一下MySQL基…

2022年NOC大赛创客智慧编程赛道图形化scratch复赛题,包含答案解析

目录 2022 年 NOC 大赛创客智慧编程图形化复赛用题 下载文档打印做题:

ArcGIS Pro、Python、USLE、INVEST模型等多技术融合的生态系统服务构建生态安全格局

第一章、生态安全评价理论及方法介绍 一、生态安全评价简介 ​ 二、生态服务能力简介 ​ 三、生态安全格局构建研究方法简介 ​ 第二章、平台基础一、ArcGIS Pro介绍1. ArcGIS Pro简介2. ArcGIS Pro基础3. ArcGIS Pro数据编辑4. ArcGIS Pro空间分析5. 模型构建器6. ArcGIS Pro…

命令执行的判断根据:;、、

文章目录 命令执行的判断根据&#xff1a;;、&&、||cmd ; cmd(不考虑命令相关性的连续命令执行)$?(命令返回值)与&&或||使用案例例题 命令执行的判断根据&#xff1a;;、&&、|| 在某些情况下&#xff0c;我想要一次执行很多命令&#xff0c;而不想分…

【jvm系列-10】深入理解jvm垃圾回收器的种类以及内部的执行原理

JVM系列整体栏目 内容链接地址【一】初识虚拟机与java虚拟机https://blog.csdn.net/zhenghuishengq/article/details/129544460【二】jvm的类加载子系统以及jclasslib的基本使用https://blog.csdn.net/zhenghuishengq/article/details/129610963【三】运行时私有区域之虚拟机栈…

JavaScript字符串操作

ASCII&#xff08;as key&#xff09; 字符集&#xff08;了解&#xff09; 我们都知道&#xff0c;计算机只能存储 0101010 这样的二进制数字&#xff0c;那么我们的 a ~ z / A ~ Z / $ / /… 之类的内容也有由二进制数字组成的 我们可以简单的理解为&#xff0c; a ~ z / …