React 如何进行路由变化监听
一、使用`react-router`库(以`react-router-dom`为例)
1. 历史(`history`)对象监听
1.1 原理
`react-router`内部使用`history`对象来管理路由历史记录。可以通过访问`history`对象来监听路由变化。在基于类的组件中,可以通过组件的`props`获取`history`对象;在函数式组件中,可以使用`useHistory`钩子函数获取。
1.2 示例(基于类的组件)
import React from "react";import { withRouter } from "react-router-dom";class MyComponent extends React.Component {componentDidMount() {this.props.history.listen((location, action) => {console.log("路由发生变化,新位置:", location);console.log("路由变化的动作:", action);});}render() {return <div>这是一个组件</div>;}}export default withRouter(MyComponent);
在这里,`componentDidMount`生命周期方法中,通过`this.props.history.listen`来添加一个路由变化的监听器。每当路由发生变化时,就会打印出新的位置(`location`)和路由变化的动作(`action`,如`PUSH`、`REPLACE`等)。
1.3 示例(函数式组件)
import React from "react";import { useHistory } from "react-router-dom";function MyComponent() {const history = useHistory();React.useEffect(() => {const unlisten = history.listen((location, action) => {console.log("路由发生变化,新位置:", location);console.log("路由变化的动作:", action);});return () => {unlisten();};}, [history]);return <div>这是一个函数式组件</div>;}export default MyComponent;
在函数式组件中,使用`useHistory`钩子获取`history`对象,然后在`useEffect`钩子中添加监听器。同时,返回一个清理函数,用于在组件卸载时移除监听器。
2. `useLocation`钩子监听(推荐用于函数式组件)
2.1 原理
`useLocation`是`react-router-dom`提供的一个钩子函数,它返回当前的`location`对象。通过比较前后`location`对象的变化,可以检测到路由是否发生了变化。
2.2 示例
import React from "react";import { useLocation } from "react-router-dom";function MyComponent() {const location = useLocation();React.useEffect(() => {console.log("当前路由位置:", location);}, [location]);return <div>这是一个函数式组件</div>;}export default MyComponent;
在这里,`useEffect`钩子依赖`location`对象。每当`location`发生变化(即路由变化)时,`useEffect`中的回调函数就会被执行,打印出当前的路由位置。
3. 自定义事件监听(不依赖`react-router`内部机制)
3.1 原理
在顶层组件(如`App`组件)中,通过`window`对象的`addEventListener`方法监听`hashchange`(对于哈希路由)或`popstate`(对于 HTML5 历史记录路由)事件来检测路由变化。这种方法比较底层,需要自己处理更多的细节,比如区分不同类型的路由和处理事件冒泡等问题。
3.2 示例(以哈希路由为例)
import React from "react";function App() {React.useEffect(() => {const handleHashChange = () => {console.log("哈希路由发生变化,当前哈希:", window.location.hash);};window.addEventListener("hashchange", handleHashChange);return () => {window.removeEventListener("hashchange", handleHashChange);};}, []);return <div>{/* 路由相关组件和内容 */}</div>;}export default App;
在`App`组件的`useEffect`钩子中,添加了一个`hashchange`事件监听器。当哈希路由发生变化时,就会打印出当前的哈希值。注意,在返回的清理函数中,要移除添加的监听器,以避免内存泄漏。
相关文章:
React 如何进行路由变化监听
一、使用react-router库(以react-router-dom为例) 1. 历史(history)对象监听 1.1 原理 react-router内部使用history对象来管理路由历史记录。可以通过访问history对象来监听路由变化。在基于类的组件中,可以通过组…...
Unity UGUI使用技巧与经验总结(不定期更新)
Text自动缩放参考连接: Unity -UGUI中Text文本框的自动调整,字体大小的自适应调节_unity添加的字体大小锁定-CSDN博客 Toggle按钮选择时,显示对应的UI界面: 为Toggle组件的On Value Change事件添加对需要显示的对象的SetActive…...
中国乡镇界shp全境arcgis格式shp数据乡镇名称下载后内容测评
下载乡镇界shp链接:https://download.csdn.net/download/zhongguonanren99/19354855 标题中的“中国乡镇界shp全境arcgis格式shp数据乡镇名称2012年”揭示了这个数据集的核心内容。它是一个地理信息系统(GIS)数据,具体来说是使用…...
第 31 章 - 源码篇 - Elasticsearch 写入流程深入分析
写入源码分析 接收与处理 请求首先会被 Netty4HttpServerTransport 接收,接着交由 RestController 进行路由分发。 private void tryAllHandlers(final RestRequest request, final RestChannel channel, final ThreadContext threadContext) throws Exception {…...
node.js下载、安装、设置国内镜像源(永久)(Windows11)
目录 node-v20.18.0-x64 工具下载安装设置国内镜像源(永久) node-v20.18.0-x64 工具 系统:Windows 11 下载 官网https://nodejs.org/zh-cn/download/package-manager 版本我是跟着老师选的node-v20.18.0-x64如图选择 Windows、x64、v2…...
小于n的最大数 - 贪心算法 - C++
字节经典面试题 给定一个整数n,并从1~9中给定若干个可以使用的数字,根据上述两个条件,得到每一位都为给定可使用数字的、最大的小于整数n的数,例如,给定可以使用的数字为 {2,3,8} 三个数:给定 n3589&#x…...
【顶刊TPAMI 2025】多头编码(MHE)之极限分类 Part 3:算法实现
目录 1 三种多头编码(MHE)实现1.1 多头乘积(MHP)1.2 多头级联(MHC)1.3 多头采样(MHS)1.4 标签分解策略 论文:Multi-Head Encoding for Extreme Label Classification 作者…...
解决CentOS 8 YUM源更新后报错问题:无法下载AppStream仓库元数据
背景介绍 在尝试更新CentOS 8的YUM源以使用阿里云镜像时,遇到了Failed to download metadata for repo appstream的错误。此错误通常出现在执行yum clean all && yum makecache命令之后,表明系统无法从指定的URL获取AppStream仓库的元数据。本文…...
[python3]Excel解析库-openpyxl
https://openpyxl.readthedocs.io/en/stable/ openpyxl 是一个用于读写 Excel 2010 xlsx/xlsm/xltx/xltm 文件的 Python 库。它允许开发者创建、修改和保存电子表格,而无需依赖 Microsoft Excel 软件本身。openpyxl 支持读取和写入 Excel 的工作簿(Work…...
Docker 远程访问完整配置教程以及核心参数理解
Docker 远程访问完整配置教程 以下是配置 Docker 支持远程访问的完整教程,包括参数说明、配置修改、云服务器安全组设置、主机防火墙配置,以及验证远程访问的详细步骤。 1. 理解 -H fd:// 参数的作用(理解了以后容易理解后面的操作ÿ…...
王老吉药业SRM系统上线 携手隆道共启战略合作新篇章
12月27日,广州王老吉药业股份有限公司(简称“王老吉药业”)SRM项目上线启动会,在王老吉科普教育基地——“吉园”隆重举行。广药集团纪委主任陈耕、王老吉药业总工程师黄晓丹、隆道公司总裁吴树贵、项目经理赵耀、供应商代表郭伟及…...
MyBatis 配置文件全解析
一、MyBatis 配置文件为何至关重要? 在 Java 后端开发领域,MyBatis 作为一款广受欢迎的持久层框架,极大地简化了数据库操作。而 MyBatis 配置文件,恰似整个框架的 “神经中枢”,掌控着其运行的方方面面,对…...
unity学习6:unity的3D项目的基本界面和菜单
目录 1 unity界面的基本认识 1.1 file 文件 1.2 edit 编辑/操作 1.3 Assets 1.4 gameobject 游戏对象 1.5 组件 1.6 windows 2 这些部分之间的关系 2.1 关联1: Assets & Project 2.2 关联2:gameobject & component 2.3 关联3…...
企业二要素如何用C#实现
一、什么是企业二要素? 企业二要素,通过输入统一社会信用代码、企业名称或统一社会信用代码、法人名称,验证两者是否匹配一致。 二、企业二要素适用哪些场景? 例如:信用与金融领域 1.信用评级:信用评级…...
中科院空天院无人机视觉语言导航新基准!AeroVerse:模拟、预训练、微调和评估空中无人机具身世界模型的测试基准
作者: Fanglong Yao, Yuanchang Yue, Youzhi Liu, Xian Sun, Kun Fu 单位:中国科学院空天信息创新研究院网络信息系统技术重点实验室,中国科学院大学电子电气与通信工程学院 原文链接: AeroVerse: UAV-Agent Benchmark Suite fo…...
Python安装(新手详细版)
前言 第一次接触Python,可能是爬虫或者是信息AI开发的小朋友,都说Python 语言简单,那么多学一些总是有好处的,下面从一个完全不懂的Python 的小白来安装Python 等一系列工作的记录,并且遇到的问题也会写出,…...
Oracle DG备库数据文件损坏修复方法(ORA-01578/ORA-01110)
今天负责报表的同事反馈在DG库查询时出现如下报错 ORA-01578:ORACLE数据块损坏(文件号6,块号 2494856)ORA-01110:数据文件6: /oradata/PMSDG/o1 mf users_molczgmn_.dbfORA-26040:数据块是使用 NOLOGGING 选项加载的 可以看到报错是数据文件损坏,提示了file id和b…...
安装Linux
在Linux系统上安装MySQL数据库,可以根据服务器是否有网络连接选择不同的安装方式。以下分别介绍在线安装(通过yum)和离线安装(手动下载.tar包)的详细步骤: 一、在线安装(通过yum) 检…...
【文献精读笔记】Explainability for Large Language Models: A Survey (大语言模型的可解释性综述)(四)
****非斜体正文为原文献内容(也包含笔者的补充),灰色块中是对文章细节的进一步详细解释! 四、提示范式(Explanation for Prompting Paradigm) 随着语言模型规模的扩大,基于提示(prom…...
【OpenCV】使用Python和OpenCV实现火焰检测
1、 项目源码和结构(转) https://github.com/mushfiq1998/fire-detection-python-opencv 2、 运行环境 # 安装playsound:用于播放报警声音 pip install playsound # 安装opencv-python:cv2用于图像和视频处理,特别是…...
SigmaStar SSC335/SSC337 ISP烧录避坑指南:为什么你的FLASH启动不了?
SigmaStar SSC335/SSC337 ISP烧录避坑指南:为什么你的FLASH启动不了? 当你满怀期待地按下电源键,却发现开发板毫无反应——这种挫败感每个嵌入式开发者都深有体会。SSC335/SSC337作为智能视觉处理领域的明星芯片,其ISP烧录过程看似…...
Vue 3快速Diff算法源码级深度剖析
Vue 3快速Diff算法源码级深度剖析 一、算法设计哲学:最小化DOM操作 Vue 3的Diff算法以"最小化真实DOM操作"为核心目标,通过五步优化策略实现性能飞跃。不同于Vue 2的双指针递归比较,Vue 3采用分治策略将复杂列表比较拆解为五个子问…...
颠覆传统认知!Science新研究|学习让大脑神经元更“合群”,而非更“独立”
当你在某项技能上愈发熟练,比如在人群中一眼认出熟悉的面孔、快速发现文字里的拼写错误,或是精准预测游戏中的下一步动作时,大脑中的感觉神经元并不会变得更独立地工作,反而会变得愈发协调,彼此共享信息、协同行动。这…...
信号与系统分析2026(春季)作业参考答案 - 第一次作业
信号与系统2025(春季)作业要求及参考答案汇总信号与系统2026(春季)作业要求及参考答案汇总 01 基础作业一、绘制信号波形 1、必做题...
Python新手必看:5分钟搞定BMI计算器(附完整代码及format函数详解)
Python新手实战:从零构建BMI计算器与字符串格式化深度解析 在编程学习的起步阶段,能够快速实现一个看得见、用得着的小工具,往往比学习抽象概念更能激发持续学习的动力。BMI(身体质量指数)计算器就是一个绝佳的练手项目…...
别再乱用#0延迟了!SystemVerilog仿真器事件队列的底层逻辑与实战避坑指南
SystemVerilog仿真器事件队列的深度解析与#0延迟陷阱规避实战 在数字IC验证与设计领域,SystemVerilog仿真过程中的时序问题一直是工程师们面临的棘手挑战。许多开发者习惯性地使用#0延迟作为解决竞争条件的"银弹",却不知这实际上是在掩盖问题而…...
如何在 Linux 系统安装 Nginx?附可视化安装与管理教程
很多人在刚接触服务器时,都会遇到一个非常实际的问题:如何在系统安装 Nginx? Nginx 作为目前最常用的 Web 服务软件之一,广泛应用于静态网站部署、反向代理、负载均衡、HTTPS 证书配置以及前后端项目发布。对于运维人员、站长或者…...
uni-app打包完整流程
📦 app打包完整流程 > 操作系统要求:macOS(Transporter 仅支持 Mac) 一、打包前准备 1. 设置环境变量 在 App.vue 文件中,设置 isProd 变量用于区分测试环境和正式环境: // App.vue let isProd = true // 正式环境设为 true,测试环境设为 false> 💡 提示:…...
Zotero SciPDF插件终极指南:三步实现文献PDF自动下载
Zotero SciPDF插件终极指南:三步实现文献PDF自动下载 【免费下载链接】zotero-scipdf Download PDF from Sci-Hub automatically For Zotero7 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-scipdf 还在为文献下载而烦恼吗?Zotero SciPDF插…...
JetBrains IDE评估期重置技术解析:跨平台配置清理与插件化实现方案
JetBrains IDE评估期重置技术解析:跨平台配置清理与插件化实现方案 【免费下载链接】ide-eval-resetter 项目地址: https://gitcode.com/gh_mirrors/id/ide-eval-resetter 在JetBrains系列IDE开发环境中,评估期限制是开发者在学习和测试阶段面临…...
