一天搞定React(5)——ReactRouter(下)【已完结】

news2024/12/23 12:31:59

     Hello!大家好,今天带来的是React前端JS库的学习,课程来自黑马的往期课程,具体连接地址我也没有找到,大家可以广搜巡查一下,但是总体来说,这套课程教学质量非常高,每个知识点都有一个小案例,最后有一个总的美团外卖案例教学,大家可以看看我这篇文章,如果能够帮到你们,还请多多点赞o( ̄▽ ̄)d支持支持🌹,如果文章中有错误的或者是遗漏信息,可以在评论区指出或者是与我私信。我看到了消息,一定会及时更正过来∠(°ゝ°)。话不多说,直接开学💪⛽️

     本篇教学已完结,具体可查看教程:
1. 一天搞定React(1)——React安装与配置
2. 一天搞定React(2)——JSX语法
3. 一天搞定React(3)——Hoots组件
4. 一天搞定React(4)——Redux
5. 一天搞定Recat(5)——ReactRouter(上)
6. 一天搞定React(5)——ReactRouter(下)

文章目录

    • 嵌套路由
      • 默认二级路由
      • 404路由配置
    • 两种路由模式

嵌套路由

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

步骤:

  1. 使用children属性配置路由嵌套关系

    const router = createBrowserRouter([
    	{
    		path:'/第一个页面名称',
    		element:<组件一 />
    		children:[	//使用`children`属性配置路由嵌套关系
    			{
    				path:'/嵌套组件名称',
    				element:<组件二 />
    			}
    		]
    	},
    ])
    
  2. 来到一级路由组件内部,使用<Outlet/>组件配置二级路由渲染位置

    import{ Link,Outlet } from 'react-router-dom'
    const 一级组件名称 =()=>{
    	return(
    		<div>
    			<Link to="/嵌套组件路径">嵌套组件</Link>
    			<Outlet />	//配置二级路由的出口
    		</div>
    		)
    }
    
    export default Layout
    

默认二级路由

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

  1. 添加index: true属性实现默认二级路由

    children:[	//设置为默认二级路由一级路由访问的时候,它也能得到渲染
    			{
    				index: true,
    				element:<组件二 />
    			}
    
  2. 在一级组件里面配置

    const 一级组件名称 =()=>{
    	return(
    		<div>
    			<Link to="/">嵌套组件</Link>	//因为path已经去掉了,所以没有必要再写上路径
    			<Outlet />	//配置二级路由的出口
    		</div>
    		)
    }
    

404路由配置

当浏览器输入url的路径在整个路由配置中都找不到对应的path,为了用户体验,可以使用404兜底组件进行渲染。这样就可以提示用户出现了404错误。

步骤:

  1. 准备一个NotFound组件(新建一个NotFound包,里面创建一个index.js文件)

    const NotFound = ()={
    	return <div>出现404错误</div>
    }
    export default NotFound
    
  2. 在路由表数组的末尾,以*号作为路由path配置路由

    const router = createBrowserRouter([
    	{
    		path:'/第一个页面名称',
    		element:<组件一 />
    		children:[	//使用`children`属性配置路由嵌套关系
    			{
    				path:'/嵌套组件名称',
    				element:<组件二 />
    			}
    		]
    	},
    	//在路由表数组的末尾,以`*`号作为路由path配置路由
    	{
    		path:`*`,
    		element:<NotFound />
    	}
    ])
    

两种路由模式

与vue一样也是有两种路由模式,history模式和hash模式。ReactRouter分别由createBrowerRoutercreateHashRouter函数负责创建。

这两种模式一共有以下区别:

  1. Hash模式:
    • 使用URL中的#号来标记路由路径(如http://example.com/#/home)。
    • 不会引起页面重新加载,兼容性较好,所有现代浏览器都支持。
    • 适用于对SEO要求不高或需要兼容老旧浏览器的场景。
  2. History模式:
    • 利用HTML5 History API(如pushStatereplaceState)实现URL的更新,无需#号(如http://example.com/home)。
    • 可以实现更美观的URL地址,但需要服务器端的配合来确保深层链接的有效性。
    • 适用于对SEO有一定要求或需要更美观URL地址的场景。

image-20240726182324671

在我们之前一直用的都是history路由模式来编写的。

import {createBrowserRouter} from 'react-router-dom'
const router = createBrowserRouter([
	{
		path:'/第一个页面名称',
		element:<组件一 />
	},
])

使用hash路由模式如下:

import {createHashRouter} from 'react-router-dom'		//只需要将原来的`createBrowerRouter`更改为`createHashRouter`
const router = createHashRouter([
	{
		path:'/第一个页面名称',
		element:<组件一 />
	},
])

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

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

相关文章

全球“微软蓝屏”事件:IT基础设施韧性与安全性的考验

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…

Firefox扩展程序和Java通信

实现Firefox扩展程序&#xff0c;和Java RMI Client端进行通信。 在Firefox工具栏注册按钮&#xff0c;点击按钮后弹出Popup.html页面&#xff0c;引用Popup.js脚本&#xff0c;通过脚本向Java RMI client发送消息&#xff0c;Java RMI Client接收消息后转发到Java RMI Server…

Hadoop3:HDFS的客户端工具Big Data Tools(IDEA版本)

1、安装插件 在Plugins里搜索Big Data Tools 安装完成后&#xff0c;重启IDEA 2、配置Windows环境 主要是配置Hadoop环境&#xff0c;否则无法通过插件远程连接HDFS 1、解压hadoop安装包 2、进入hadoop的bin目录 放入图中标红的两个文件 3、配置hadoop环境变量 新建HAD…

夯实数字经济的“新基建”-基于大数据与区块链技术的新型基础设施

随着我国数据市场的蓬勃发展&#xff0c;构建契合数据特性、加速数据流通与价值释放的新型数据基础设施变得尤为关键。数字基础设施作为数字经济蓬勃发展的基石&#xff0c;其完善与否直接关系到数据能否有效存储、顺畅流通及高效利用&#xff0c;进而促进数据资源向数据资产的…

电脑蓝屏怎么回事?这里有全面的解决方案

电脑蓝屏是Windows操作系统中一种常见且令人头疼的问题。当电脑遇到无法处理的错误时&#xff0c;系统会自动停止运行并显示蓝屏&#xff0c;提示用户出现了严重问题。蓝屏不仅打断了工作和娱乐&#xff0c;还可能导致数据丢失。那么电脑蓝屏怎么回事呢&#xff1f;本文将介绍电…

视觉-语言-行动模型:将网络知识迁移至机器人控制(RT-2论文翻译)

RT-2: Vision-Language-Action Models Transfer Web Knowledge to Robotic Control RT-2: 用互联网知识训练的视觉语言模型融入到机器人控制中 RT1 论文翻译&#xff1a; https://blog.csdn.net/weixin_43334869/article/details/135850410 文章目录 RT-2: Vision-Language…

机器学习(五) -- 无监督学习(1) --聚类1

系列文章目录及链接 上篇&#xff1a;机器学习&#xff08;五&#xff09; -- 监督学习&#xff08;7&#xff09; --SVM2 下篇&#xff1a;机器学习&#xff08;五&#xff09; -- 无监督学习&#xff08;1&#xff09; --聚类2 前言 tips&#xff1a;标题前有“***”的内容…

Git 基础 GitHub【学习笔记】

一、Git 优势 大部分操作在本地完成&#xff0c;不需要联网完整性保证尽可能添加数据而不是删除或修改数据分支操作非常快捷流畅与 Linux 命令全面兼容 二、Git 程序安装 https://git-scm.com 三、Git 结构 #mermaid-svg-9Go6R1leWXWrDCqn {font-family:"trebuchet ms&quo…

【更新2022】地级市城镇 农村居民可支配收入 2001-2022

地级市城镇和农村居民的可支配收入可以用于各种科研领域。他们可以用这些资金支持基础科学研究&#xff0c;推动新技术和创新的发展。他们可以投资于医学研究&#xff0c;促进健康和医疗领域的进步。他们还可以支持环境科学研究&#xff0c;以解决环境问题和可持续发展挑战。此…

2.1、matlab绘图汇总(图例、标题、坐标轴、线条格式、颜色和散点格式设置)

1、前言 在 MATLAB 中进行绘图是一种非常常见且实用的操作&#xff0c;可以用来可视化数据、结果展示、分析趋势等。通过 MATLAB 的绘图功能&#xff0c;用户可以创建各种类型的图形&#xff0c;包括线图、散点图、柱状图、曲线图等&#xff0c;以及三维图形、动画等复杂的可视…

C语言 | Leetcode C语言题解之第295题数据流的中位数

题目&#xff1a; 题解&#xff1a; typedef struct Heap {int* array; //存放堆的数组int capacity;//数组的容量int len; //已存数组的大小 }Heap;/*大小根堆切换开关*/ int HeapLen(Heap* hp); //heap获取当前的堆大小 void Heap…

安装VMware Workstation Pro

一、下载 通过百度网盘分享的文件&#xff1a;VMware-workstation-full-16.2.4-2008... 链接&#xff1a;https://pan.baidu.com/s/1mDnFhLQErBlpeX_KjsgtzA 提取码&#xff1a;0bw7 二、安装 &#xff08;1&#xff09;双击exe文件 &#xff08;2&#xff09;安装软件 &…

本地部署Graphhopper路径规划服务(graphhopper.sh启动版)

文章目录 文章参考源码获取一、配置Java环境变量二、配置Maven环境变量三、构建graphhopper步骤1. 下载数据2. 配置graphhopper配置文件config-example.yml3. 在项目中启动命令行执行./graphhopper.sh build3.1|、遇到的问题3.1.1、pom.xml中front-maven-plugin-无法下载npm6.1…

结构型设计模式-组合模式

一、组合模式 对于这个图片肯定会非常熟悉&#xff0c;上图我们可以看做是一个文件系统&#xff0c;对于这样的结构我们称之为树形结构。在树形结构中可以通过调用某个方法来遍历整个树&#xff0c;当我们找到某个叶子节点后&#xff0c;就可以对叶子节点进行相关的操作。可以将…

Python安装库太慢?配置好这个速度飞起

经常听到初学python的小伙伴在抱怨&#xff0c;python安装第三方库太慢&#xff0c;很容易失败报错&#xff0c;如果安装pandas、tensorflow这种体积大的库&#xff0c;简直龟速。 为什么pip会很慢&#xff1f; 先来了解下pip&#xff0c;pip是一个非常流行的python包管理工具…

【苍穹】完美解决由于nginx更换端口号导致无法使用Websocket

一、报错信息 进行到websocket开发的过程中&#xff0c;遇到了前端报错&#xff0c;无法连接的提示&#xff1a; 经过F12排查很明显是服务端和客户端并没有连接成功。这里就涉及到之前的坑&#xff0c;现在需要填上了。 二、报错原因和推导 应该还记得刚开苍穹的第一天配置前…

技术实践—微前端技术应用

微前端是一种新兴的前端架构模式&#xff0c;是一种类似于微服务的架构&#xff0c;将微服务的理念应用于浏览器端。其核心理念是将一个大而单一的前端应用拆分为多个小型独立的微应用。这些微应用各自独立&#xff0c;可以由不同团队开发维护&#xff0c;部署&#xff0c;组合…

docker发布镜像到自己远程私有仓库

1、登录docker hub创建自己的仓库地址&#xff1a;https://hub.docker.com/repository/create 输入仓库名称 2.构建镜像 略过。。。。请自己查找别的资料&#xff0c;此篇文章只讲述镜像推送到远程 3.推送 假设你已经构建了一个镜像 web/online-editor:latest&#xff0c;现…

【React学习打卡第二天】

受控表单绑定、React获取Dom\组件通信、useEffect、自定义hook函数和ReactHooks使用规则 一、受控表单绑定1.准备React状态值2.通过value属性绑定状态&#xff0c;通过onChange属性绑定状态同步的函数 二、React中获取DOM1. 使用useRef创建 ref 对象&#xff0c;并与 JSX 绑定2…

使用图数据库Nebula Graph快速上手史上最大规模的中文知识图谱ownthink_v2教程(没写完,明天再写)

一、前言 本教程主要参考官方教程&#xff1a;使用图数据库 Nebula Graph 数据导入快速体验知识图谱 OwnThink (nebula-graph.com.cn) 来带着大家一步一步复现实验内容。 本教程主要使用到的数据集&#xff1a; ownthink/KnowledgeGraphData: 史上最大规模1.4亿中文知识图谱…