Blazor University (27)路由 —— 检测导航事件

原文链接:https://blazor-university.com/routing/detecting-navigation-events/

检测导航事件

源代码[1]

从 Blazor 访问浏览器导航是通过 NavigationManager 服务提供的。这可以使用 razor 文件中的 @inject 或 CS 文件中的 [Inject] 属性注入到 Blazor 组件中。

LocationChanged 事件

LocationChanged 是在浏览器中的 URL 发生更改时触发的事件。它传递一个 LocationChangedEventArgs 实例,该实例提供以下信息:

public readonly struct LocationChangedEventArgs
{public string Location { get; }public bool IsNavigationIntercepted { get; }
}

Location 属性是显示在浏览器中的完整 URL,包括协议、路径和任何查询字符串。

IsNavigationIntercepted 指示导航是通过代码还是通过 HTML 导航启动的。

  • false

    导航由从代码调用的 NavigationManager.NavigateTo 启动。

  • true

    用户单击 HTML 导航元素(例如 a href),Blazor 拦截导航,而不是允许浏览器实际导航到新 URL,这将导致向服务器发出请求。在其他情况下也是如此,例如页面上的某些 JavaScript 导致导航(例如,在超时之后)。最终,任何不是通过 NavigationManager.NavigateTo 发起的导航事件都将被视为拦截导航,并且该值为 true

请注意,目前无法拦截导航并阻止其继续进行。

观察 OnLocationChanged 事件

需要注意的是,NavigationManager 服务是一个长期存在的实例。因此,任何订阅其 LocationChanged 事件的组件都将在服务的生命周期内被强引用。因此,重要的是我们的组件在它们被销毁时也取消订阅此事件,否则它们将不会被垃圾收集。

目前,ComponentBase 类在销毁时没有生命周期事件,但可以实现 IDisposable 接口。

@implement IDisposable
@inject NavigationManager NavigationManagerprotected override void OnInitialized()
{// Subscribe to the eventNavigationManager.LocationChanged += LocationChanged;base.OnInitialized();
}void LocationChanged(object sender, LocationChangedEventArgs e)
{string navigationMethod = e.IsNavigationIntercepted ? "HTML" : "code";System.Diagnostics.Debug.WriteLine($"Notified of navigation via {navigationMethod} to {e.Location}");
}void IDisposable.Dispose()
{// Unsubscribe from the event when our component is disposedNavigationManager.LocationChanged -= LocationChanged;
}

参考资料

[1]

源代码: https://github.com/mrpmorris/blazor-university/tree/master/src/Routing/NavigatingViaCode

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

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

相关文章

创建 overlay 网络 - 每天5分钟玩转 Docker 容器技术(50)

上一节我们搭建好实验环境,配置并运行了consul,今天开始创建 overlay 网络。 在 host1 中创建 overlay 网络 ov_net1: -d overlay 指定 driver 为 overaly。 docker network ls 查看当前网络: 注意到 ov_net1 的 SCOPE 为 global&…

Js+Css 控制iframe内容自动缩放

竖屏横屏效果<div class"h5box"> <iframe src"http://player.youku.com/embed/XMTI4MjU5OTA3Mg" frameborder"0" width"1280px" height"720px"></iframe> </div><script type"tex…

西北冬日的校园很静谧,却不失韵味,因为有我们美好的青春!

冬日的校园&#xff0c;从枯黄的落叶开始。。。 落叶与栅栏情深。 冬日的篮球场上&#xff0c;不乏挥汗如雨的你&#xff0c;因为你是梦想与自由的追逐者&#xff0c;你可以战胜自己的懒惰。 我们的测量实训场&#xff0c;英雄的用武之地。 测桩&#xff1a;测量的控制点&#…

ps、top 、free查看用户资源信息

查看root用户的进程信息。 运行命令&#xff1a; ps -u root 查看oracle用户的进程信息。 运行命令&#xff1a; ps -u oracle 若查看现在的资源占用情况&#xff0c;如何呢&#xff1f; 运行命令&#xff1a; top 可以很详细的查看各个进程的运行情况。 若查看内存使用情…

《iVX 高仿美团APP制作移动端完整项目》02 搜索、搜索提示及类别需求分析思路及制作流程

点击整个专栏查看其它系列文章 &#xff08;系列文章更新中…&#xff09;&#xff1a;《iVX 高仿美团APP制作移动端完整项目》 项目界面预览&#xff1a; 一、搜索制作 在上一节中我们完成了标题头的制作&#xff0c;接下来我们查看如何制作搜索栏以及分类区制作。 首先我…

C语言试题十一之计算并输出下列多项式值:sn=(1-1/2)+(1/3-1/4)+…+(1/(2n-1)1/2n).

📃个人主页:个人主页 🔥系列专栏:C语言试题200例目录 💬推荐一款刷算法、笔试、面经、拿大公司offer神器 👉 点击跳转进入网站 ✅作者简介:大家好,我是码莎拉蒂,CSDN博客专家(全站排名Top 50),阿里云博客专家、51CTO博客专家、华为云享专家 1、 题目 请编写函…

C#封装FluentValidation,用了之后通篇还是AbstractValidator,真的看不下去了

讲故事前几天看公司一个新项目使用了FluentValidation&#xff0c;大家都知道FluentValidation是一个非常强大的用于构建强类型验证规则的 .NET 框架&#xff0c;帮程序员解决了繁琐的校验问题&#xff0c;用起来非常爽&#xff0c;但我还是遇到了一件非常不爽的事情,如下代码所…

用批处理修复 win10 无法升级的问题

win10无法升级&#xff0c;通常的做法是先停止windows update 服务&#xff0c;删除临时缓存升级目录&#xff0c;重新启动升级服务。 写成一个批处理文件&#xff0c;直接用管理员身份运行一下就搞定。echo offfor /f "skip3 tokens4" %%i in (sc query wuauserv) d…

http304状态码缓存设置问题

当浏览器第一次加载资源的时候&#xff0c;返回一般为200&#xff0c;意思是成功获取资源&#xff0c;并会在浏览器的缓存中记录下max-age&#xff0c;第二次访问的时候&#xff1a;如果只是用浏览器打开&#xff0c;那么浏览器会去判断这个资源在缓存里有没有&#xff0c;如果…

10.2.0.5启动enterprise manager

10.2.0.5启动enterprise manager OEM作为一个实用工具&#xff0c;随着10g和11g的普及&#xff0c;OEM功能越来越强大&#xff0c;oem也应用越来越广泛。但是如果是10.2.0.5的版本&#xff0c;并且安装时间在2010年1月之后&#xff0c;可能会遇到OEM无法启动的情况&#xff0c;…

【数据结构与算法】多种语言(VB、C、C#、JavaScript)系列数据结构算法经典案例教程合集目录

文章目录1. 专栏简介2. 专栏地址3. 专栏目录1. 专栏简介 2. 专栏地址 「 刘一哥与GIS的故事 」之《数据结构与算法》 3. 专栏目录 【经典回放】多种语言系列数据结构算法&#xff1a;二叉树&#xff08;JavaScript版&#xff09;【经典回放】多种语言系列数据结构算法&#…

《iVX 高仿美团APP制作移动端完整项目》03 推介信息及推荐商家分析及制作

点击整个专栏查看其它系列文章 &#xff08;系列文章更新中…&#xff09;&#xff1a;《iVX 高仿美团APP制作移动端完整项目》 项目界面预览&#xff1a; 一、推荐信息制作 推荐信息与之前的标题下推荐信息制作类似&#xff1a; 此时依旧创建一个行&#xff0c;设置其上下…

C语言试题十二之m个人的成绩存放在score数组中,请编写函数function,它的功能是:将低于平均分的人数作为函数值返回,将低于平均分的分数放在below所指定的数组中。

✅作者简介:大家好我是码莎拉蒂,CSDN、华为云、阿里云、51CTO博客专家🥇🥇🥇 📃个人主页:个人主页 🔥系列专栏:C语言试题200例目录 💬推荐一款刷算法、笔试、面经、拿大公司offer神器 👉 点击跳转进入网站 1、 题目 m个人的成绩存放在score数组中,请编写函…

yum的三种方式

RHEL5中实现各种服务的准备条件&#xff1a;(一)、制作YUM本地源&#xff1a;YUM简介&#xff1a;YUM是Yellow dog Updater Modified的简称&#xff0c;yum是软件的仓库&#xff0c;它可以是http或ftp站点&#xff0c;也可以是本地软件池&#xff0c;但必须包含rpm的header&…

利用百度云盘API上传文件至百度云盘

一、获取Access Token示例 1. 请您将以下HTTP请求直接粘贴到浏览器地址栏内&#xff0c;并按下回车键。 https://openapi.baidu.com/oauth/2.0/authorize?response_typetoken&client_idL6g70tBRRIXLsY0Z3HwKqlRE&redirect_urioob&scopenetdisk 2、执行后&#x…

Docker 容器抓包

背景介绍程序在运行期间出现问题时&#xff0c;通常会通过抓包的方式来分析、定位问题。非容器应用一般可以通过 fiddler、wireshark 等工具进行抓包&#xff0c;那么&#xff0c;运行在容器的应用一般通过什么方式进行抓包呢&#xff1f;容器应用一般可以通过 tcpdump、ngrep …

服务发现与健康监测框架Consul-DNS转发的应用

关于Consul Consul是一个提供服务注册与发现&#xff0c;健康监测&#xff0c;Key/Value存储以及多数据中心存储的分布式框架。官网地址是https://www.consul.io/&#xff0c;公司初步应用后我们老大觉得这东西有点意思&#xff0c;随即有了翻译文档的想法&#xff0c;由于精力…

【ArcGIS风暴】ArcGIS10.6图斑椭球面积计算原理与方法

文章目录 1. 椭球面积计算原理2. ArcGIS计算图斑椭球面积3. ArcGIS计算图斑投影平面面积1. 椭球面积计算原理 <

实践 Neutron 前的两个准备工作 - 每天5分钟玩转 OpenStack(78)

上一节配置了 linux-bridge mechanism driver&#xff0c;本节再做两个准备工作&#xff1a; 1. 检视初始的网络状态。2. 了解 linux bridge 环境中的各种网络设备。 初始网络状态 我们首先考察实验环境最初始的网络状态。随着学习的深入&#xff0c;我们会对网络不断进行新的配…

《iVX 高仿美团APP制作移动端完整项目》04 美食页 标题、搜索、商家标题制作

点击整个专栏查看其它系列文章 &#xff08;系列文章更新中…&#xff09;&#xff1a;《iVX 高仿美团APP制作移动端完整项目》 项目界面预览&#xff1a; 一、美食页顶部商家页制作 1.1 页面主格调确认 该美食页为首页中美食按钮点击后进入的页面。该页面分为顶部的标题、搜…