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`事件监听器。当哈希路由发生变化时,就会打印出当前的哈希值。注意,在返回的清理函数中,要移除添加的监听器,以避免内存泄漏。

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

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

相关文章

UE5AI感知组件

官方解释&#xff1a; AI感知系统为Pawn提供了一种从环境中接收数据的方式&#xff0c;例如噪音的来源、AI是否遭到破坏、或AI是否看到了什么。 AI感知组件&#xff08;AIPerception Component&#xff09;是用于实现游戏中的非玩家角色&#xff08;NPC&#xff09;对环境和其…

[SAP ABAP] SMARTFORMS表单开发

使用事务码SMARTFORMS进入到SMARTFORMS开发界面进行表单开发 SMARTFORMS表单开发相关资料 [SMARTFORMS] 创建样式模板https://blog.csdn.net/Hudas/article/details/144946341?spm1001.2014.3001.5501[SMARTFORMS] 创建FORMhttps://blog.csdn.net/Hudas/article/details/144…

倍思氮化镓充电器分享:Super GaN伸缩线快充35W

快节奏的时代,在旅游、办公等场景下,一款高效、便捷的充电器可以让我们的生活更便捷、高效。今天就给大家推荐一款倍思氮化镓充电器——Super GaN伸缩线快充35W。它具备多重亮点,可以满足我们在许多场景下的充电需求,成为我们的得力助手。 倍思氮化镓Super GaN伸缩线快充35W的亮…

声音是如何产生的

一、音频概述 RTMP中一般音频采用aac编码&#xff0c;采样率为44100HZ, 每帧1024采样&#xff0c;帧率43&#xff0c;23.2ms一帧 RTC中一般音频采用opus编码&#xff0c;采样率为48000HZ&#xff0c;每帧480采样&#xff0c;帧率100&#xff0c;10ms一帧 通道数&#xff08;c…

xr-frame 通过shader去除视频背景色,加载透明视频

目录 前言 实现思路 获取 XR 框架系统&#xff1a; 注册自定义效果 创建效果对象 渲染通道配置 着色器代码 顶点着色器 片元着色器&#xff08;颜色分量g达到条件的片元将被透透明&#xff09; effect-removeBlack 完整代码 wxml中使用 前言 实现了一个用于注册自定…

CSS——7.CSS注释

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title>css注释</title><link rel"stylesheet" type"text/css" href"a.css"/></head><body><!--头部开始&#xff08;h…

电子信息硕士面试经验

回顾2024年秋招一些面试常见的问题,主要涉及软件开发和嵌入式部分内容。 1. 浅拷贝深拷贝 深拷贝和浅拷贝是两种不同的拷贝方式,用于复制对象。它们主要区别在于对嵌套对象的处理方式。 浅拷贝:只复制对象的顶层,嵌套对象仍然是共享引用。 深拷贝:递归复制所有对象及其嵌…

fnm教程

常用命令 // 查看所有远程可供安装的 Node 版本 fnm list-remote// 安装某一 Node 版本 fnm install <version>// 切换某一 Node 版本 fnm use <version>// 查看当前使用的 Node 版本 fnm current// 查看所有已安装的 Node 版本 fnm list// 删除某一 Node 版本 fn…

物体切割效果

1、物体切割效果是什么 在游戏开发中&#xff0c;物体切割效果就是物体看似被切割、分割或隐藏一部分的视觉效果。 这种效果常用与游戏和动画中&#xff0c;比如角色攻击时的切割效果&#xff0c;场景中的墙壁切割效果等等。 2、物体切割效果的基本原理 在片元着色器中判断片…

GTX750Ti打DP补丁

背景 咸鱼收了一个二手的GTX750Ti,用于4K60Hz显示器,HDMI接口勉强可以4K60Hz,不过色彩和帧率都不是太正常,理论上它的HDMI接口是不支持的,原本也是打算用DP接口接显示器的,但是发现接DP口之后无法通过bios的vga检测最终一直重启,在华硕B760-K的BIOS中使能CSM是可以使用…

接口测试Day06-UnitTest框架

UnitTest 是开发人员用来实现 “单元测试” 的框架。测试工程师&#xff0c;可以在自动化 “测试执行” 时使用。 使用 UnitTest 的好处&#xff1a; 方便管理、维护测试用例。提供丰富的断言方法。生成测试报告。&#xff08;需要插件 HTMLTestReport&#xff09; UnitTest框架…

《learn_the_architecture_-_trustzone_for_aarch64_102418_0101_03_en》学习笔记

1.TrustZone是Arm A-profile架构中安全架构的名称。TrustZone首次在Armv6K中引入&#xff0c;Armv7-A和Armv8-A也支持。TrustZone提供两个执行环境&#xff0c;它们之间具有系统范围的硬件强制隔离。在Arm架构中&#xff0c;有两种安全状态&#xff1a;安全和非安全。在EL0、EL…

人工智能-Python网络编程-TCP

1 TCP-概念版 服务端 import socket ​ # 1 创建服务端套接字对象 # socket.AF_INET IPV4 # socket.SOCK_STREAM TCP # socket.SOCK_DGRAM UDP tcp_server_socket socket.socket(socket.AF_INET, socket.SOCK_STREAM) ​ # 2 绑定端口号 tcp_server_socket.bind((192.…

小程序组件 —— 28 组件案例 - 推荐商品区域 - 实现结构样式

这一节目标是实现底部推荐商品的结构和样式&#xff0c;由于这里要求横向滚动&#xff0c;所以需要使用上节介绍的 scroll-view 功能&#xff0c;并使用 scroll-x 属性支持横向滚动&#xff0c;推荐商品区域中的每一个商品是一个单独的 view&#xff0c;每个view 中需要写三个组…

【Spring Boot】Spring AOP 快速上手指南:开启面向切面编程新旅程

前言 &#x1f31f;&#x1f31f;本期讲解关于spring aop的入门介绍~~~ &#x1f308;感兴趣的小伙伴看一看小编主页&#xff1a;GGBondlctrl-CSDN博客 &#x1f525; 你的点赞就是小编不断更新的最大动力 &#x1f386;那么废话不…

集合划分.

本节通过解决集合划分的问题进行一个递归算法的简单实现. 问题描述: 给定正整数n和m,计算出n个元素的集合{1,2,3....}可以划分为多少个不同的有m个非空子集组成的集合. 思路解析: 解读题目,将由n个元素组成的集合拆分成m个非空子集,假设函数名为f.若想将n个元素分成m组,就需要…

广告联盟项目实操教程

我认为很多行业就像一层窗户纸&#xff0c;捅破了大家都能听得懂&#xff0c;谁能在这个行业赚到钱&#xff0c;主要在于你能不能深入了解这个行业的运作逻辑&#xff0c;和你有没有强大的执行力&#xff0c;做到这两点&#xff0c;你不赚钱都难。广告联盟项目也一样&#xff0…

数据结构(AVL树)

BST的退化 仔细观察BST你会发现&#xff0c;虽然他有良好的“搜索”特性&#xff0c;也就是&#xff1a;你可以利用其节点之间的大小关系&#xff0c;很容易地从根节点开始往下走找到你要的节点&#xff0c;但他却无法保证这种搜索所需要的时间的长短&#xff0c;因为建立BST时…

SAP 01-初识AMDP(ABAP-Managed Database Procedure)

1. 什么是AMDP(ABAP-Managed Database Procedure) 1.&#xff09;AMDP - ABAP管理数据库程序&#xff0c;是一种程序&#xff0c;我们可以使用SQLSCRIPT在AMDP内部编写代码&#xff0c;SQLSCRIPT是一种与SQL脚本相同的数据库语言&#xff0c;这种语言易于理解和编码。 将AM…

力扣--35.搜索插入位置

题目 给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 示例 1: 输入: nums [1,3,5,6], target 5 输出: 2 示例 …