对React Router的理解

对React Router的理解

    • 1. 基本概念
    • 2. 核心组件
    • 2.1 使用React Router的基本示例:
    • 3. 路由守卫和动态路由
      • 3.1 路由守卫
      • 3.2 动态路由

React Router是React应用中实现路由功能的一个库,它允许开发者在单页应用中创建多页面应用的感觉,通过URL的变化来控制组件的显示和隐藏。React Router提供了声明式的路由配置和嵌套路由等高级功能,使得开发者可以轻松地构建复杂的应用路由结构。

1. 基本概念

  React Router的工作原理基于几个核心概念:

  • 路由(Route):定义了URL和组件之间的映射关系。
  • 路由匹配(Matching):根据当前的URL路径找到匹配的路由。
  • 路由导航(Navigation):用户通过链接或编程式导航改变URL。
  • 路由守卫(Guards):在路由跳转前执行的逻辑,如权限验证。

2. 核心组件

  React Router提供了一系列组件来帮助我们实现路由功能:

  • < BrowserRouter>:一个提供基本路由功能的组件,它使用HTML5的history API来保持UI和URL的同步。
  • < HashRouter>:类似于,但它使用URL的哈希部分来保持UI和URL的同步。
  • < Switch>:一个用于路由的容器,它会渲染第一个匹配的。
  • < Route>:定义路由规则的组件,当URL匹配时会渲染对应的组件。
  • < Link>:一个用于导航的组件,它可以创建一个指向路由的链接。
  • < NavLink>:一个装饰性的,它会根据当前路由激活状态添加CSS类。

2.1 使用React Router的基本示例:

import { BrowserRouter as Router, Route, Switch, Link, NavLink } from 'react-router-dom';
import Home from './Home';
import About from './About';
import Users from './Users';function App() {return (<Router><div><nav><ul><li><Link to="/">Home</Link></li><li><Link to="/about">About</Link></li><li><Link to="/users">Users</Link></li></ul></nav><Switch><Route exact path="/" component={Home} /><Route path="/about" component={About} /><Route path="/users" component={Users} /></Switch></div></Router>);
}

  在这个示例中,我们创建了一个简单的路由结构,包含了三个页面组件Home、About和Users。我们使用< BrowserRouter>来包裹整个应用,并在< Switch >中定义了三个,每个都对应一个路径和一个组件。 < Link >和< NavLink >用于在导航栏中创建导航链接。

3. 路由守卫和动态路由

3.1 路由守卫

  路由守卫是一种在路由跳转之前执行的逻辑,通常用于权限验证或数据预加载。在React Router中,我们可以使用高阶组件(HOC)或函数组件的属性来实现路由守卫。

import { Route, Redirect } from 'react-router-dom';function requireAuth(ComponentToProtect) {return function AuthenticatedRoute(props) {const isAuthenticated = false; // 假设从状态管理中获取if (!isAuthenticated) {return <Redirect to="/login" />;}return <ComponentToProtect {...props} />;};
}const ProtectedRoute = ({ component: Component, ...rest }) => (<Route{...rest}render={props =>isAuthenticated ? (<Component {...props} />) : (<Redirect to="/login" />)}/>
);

  在这个例子中,我们创建了一个requireAuth函数,它返回一个包装了原始组件的新组件,如果用户未认证,则重定向到登录页面。

3.2 动态路由

  动态路由允许我们根据URL参数渲染组件。在React Router中,我们可以使用参数化路径来捕获URL中的动态值。

function App() {return (<Router><Switch><Routepath="/user/:userId"render={props => <User {...props} />}/></Switch></Router>);
}function User({ match }) {const userId = match.params.userId;return <h2>User ID: {userId}</h2>;
}

  在这个例子中,我们定义了一个动态路由/user/:userId,:userId是一个参数,我们可以在User组件中通过match.params.userId来访问它。

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

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

相关文章

Python上解决TypeError: not all arguments converted during string formatting错误

目录 背景尝试1: pymysql模块的escape_string方法尝试2: 修改pandas.read_excel引擎尝试3: 回退xlrd版本总结 背景 在Linux上部署的时候, 使用pandas模块读取Excel, 然后pymysql模块入库, 结果发生了错误 Traceback (most recent call last):File "/usr/local/lib64/pyth…

3月谷歌应用上架/下架情况,上架难度加大,开发者面临新挑战?

在3月份&#xff0c;Google play应用商店应用上架和下架出现了前所未有的情况。很多开发者表示&#xff0c;上架难度简直是“地狱”级别。 下图是3月份美国、巴西、印度、中国香港的下架数量的折线图&#xff0c;根据市场数据监测&#xff0c;可以清晰地看到3月份中旬之后&…

DESTINATION MOON 香港站回顾|聆听 Web3 创新者的未来对话

创新者汇聚 Web3 行业&#xff0c;如何才能在生态、技术、投资的发展新风口把握机遇&#xff1f;「TinTin Destination Moon」香港站活动于 4 月 6 日下午如期举行&#xff01;Web3AI 的融合发展之道在哪&#xff1f;ETF 时代的投资逻辑有哪些&#xff1f;区块链未来的关键究竟…

使用HTML+CSS实现一个简单的登录页面

整个项目使用文件&#xff1a; HTML代码部分&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><ti…

【SQL】数据定义语言(DDL):包括创建、修改和删除数据库对象

数据定义语言&#xff08;DDL&#xff09;是用于定义和管理数据库中的数据结构和对象的SQL语言子集。它允许用户创建、修改和删除数据库中的表、索引、触发器、序列、存储过程等对象。DDL语句在数据库系统中执行时&#xff0c;通常会影响整个数据库的结构&#xff0c;而不是单个…

如何理解单片机 pwm 控制的基本原理?

单片机PWM&#xff08;脉宽调制&#xff09;控制的基本原理&#xff0c;简而言之&#xff0c;就是通过改变脉冲信号的宽度&#xff08;占空比&#xff09;来控制模拟电路。这涉及到单片机生成一系列脉冲信号&#xff0c;每个脉冲信号的高电平持续时间和整个周期的比值&#xff…

计算机视觉 | 基于二值图像数字矩阵的距离变换算法

Hi&#xff0c;大家好&#xff0c;我是半亩花海。本实验基于 OpenCV 实现了二值图像数字矩阵的距离变换算法。首先生成一个 480x480 的黑色背景图像&#xff08;定义黑色为0&#xff0c;白色为1&#xff09;&#xff0c;在其中随机选择了三个白色像素点作为距离变换的原点&…

MicroPython with LVGL

官方博客:Micropython LittlevGL | LVGL’s Blog github:GitHub - lvgl/lv_micropython: Micropython bindings to LVGL for Embedded devices, Unix and JavaScript 官方在线模拟器:https://sim.lvgl.io/(需要电脑能访问外网才能使用) 电脑不能访问外网会出现以下错误&…

JVM内存区域

类加载 将class文件加载到方法区中 验证&#xff1a;验证待加载的class文件是否正确&#xff0c;比如验证文件的格式 准备&#xff1a;为static变量分配内存并赋零值 解析&#xff1a;将符号引用解析为直接引用 类加载器 双亲委派 总结就是&#xff0c;向上查找有没有加载过…

面试算法-170-二叉树的最大深度

题目 给定一个二叉树 root &#xff0c;返回其最大深度。 二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;3 解 class Solution {public int maxDepth(TreeNod…

参与 PenPad Season 2 获得勋章,还有海量 Scroll 生态稀缺权益

PenPad 是 Scroll 生态中的首个 LaunchPad 平台&#xff0c;该平台继承了 Scroll 生态的技术优势&#xff0c;具备包括隐私在内的系列特点&#xff0c;同时且也被认为是 Scroll 生态最重要的价值入口之一。Penpad 与 Scroll 官方始终保持着合作&#xff0c;同时该项目自启动以来…

【C++】C++知识点复习

牛客cpp&#xff1a;牛客网在线编程 2024年4月10日:BC1—>BC8 BC4&#xff1a;浮点数精度保留 问题&#xff1a;不加入fixed输入0.359813&#xff0c;最后得到0.36&#xff0c;并不是强制保留0.360。这种写法会保留小数点后三位精度&#xff0c;但是最后输出会省略掉最后…

车载摄像头图像及画质增强解决方案

车载摄像头作为汽车智能化、安全化的关键组件&#xff0c;其图像质量直接影响着驾驶者的视觉感知和行车安全。美摄科技凭借其在图像处理和AI算法领域的深厚积累&#xff0c;推出了一款专为车载摄像头打造的图像及画质增强解决方案&#xff0c;助力企业实现摄像头画面的实时优化…

Quarkus初探

Quarkus初探 背景安装Quarkus安装Quarkus CLI 创建Quarkus项目运行Quarkus初探代码修改一下代码 数据持久化创建PanacheEntiry写入数据读取数据 Dev Service使用外部数据库区分dev和prod 构建native应用&#xff08;依赖Graalvm&#xff09; 背景 最早是在Infoq上了解到Quarku…

PKI:构建数字安全基石的关键技术

在数字化时代&#xff0c;网络安全已成为我们日常生活和工作的重要组成部分。为了确保数据的完整性、机密性和身份的真实性&#xff0c;公钥基础设施&#xff08;Public Key Infrastructure&#xff0c;简称PKI&#xff09;技术应运而生&#xff0c;为构建数字安全基石提供了重…

蓝桥杯JAVA组备赛模板1:快速幂

快速幂&#xff1a; static long gcd(long a, long b) {return b 0 ? a : gcd(b, a % b);}static long lcm(long a, long b) {return (a / gcd(a, b)) * b;}//快速幂static long powl(long a, int b) {if (a 0)return 0;long ans 1;while (b > 0) {if ((b & 1) >…

C++11 设计模式0. 设计模式的基本概念,设计模式的准则,如何学习设计模式,24种设计模式的分为3大类

一 设计模式的基本概念&#xff1a; 模式&#xff1a;指事物的标准样式 或者 理解成 针对特定问题的可重用解决方案。 设计模式&#xff0c;是在特定问题发生时的可重用解决方案。 设计模式一般用于大型项目中。 大型项目中&#xff0c;设计模式保证所设计的模块之间代码的灵…

【软考---系统架构设计师】计算机网络章节

目录 一、TCP/IP协议族 &#xff08;1&#xff09;基本介绍 &#xff08;2&#xff09;TCP和UDP的区别 &#xff08;3&#xff09;DNS协议 &#xff08;4&#xff09;DHCP协议 二、网络规划与设计 &#xff08;1&#xff09;需求分析 &#xff08;2&#xff09;通信规范…

K8S问题记录

服务器宕机导致K8S集群异常&#xff0c;部分nginx服务的pod启动失败 K8S版本&#xff1a;v1.12.5 问题1 nginx pod 启动失败&#xff0c;故障现象如下 nginx Pod 启动以后马上报错&#xff1a; [rootjd-training-cpu-01 ~]# kubectl logs -n paisystem easydl-fe-nginx-79b…

Jenkins构建时报错Error: EACCES: permission denied, open ‘/root/.npmrc解决

在使用Jenkins进行自动化构建时&#xff0c;你可能会遇到权限问题&#xff0c;如“Error: EACCES: permission denied, open ‘/root/.npmrc’”。这类问题通常与文件访问权限有关。本文将详细介绍如何识别和解决这些权限问题&#xff0c;确保你的自动化构建过程顺畅无阻。 问…