返回
Blazor获取Url路由参数的方法
2023-02-17 4453 0
这里整理了两种获取参数值的方法: 通过NavigationManager服务获取参数值和配置路由参数获取参数值。
在Blazor Server和WebAssembly中,可以通过注入 NavigationManager服务获取Uri转化为Uri对象得到Query. 然后使用HttpUtility或者QueryHelpers提供的方法获取参数值。
注入NavigationManager服务获取参数值
@code{
public string? Id { get; set; }
public string? Url { get; set; }
protected override void OnInitialized()
{
Url = NavManager.BaseUri;
// 获取Uri对象
var uri = NavManager.ToAbsoluteUri(NavManager.Uri);
// HttpUtility 获取参数值
Id = HttpUtility.ParseQueryString(uri.Query).Get("id");
// QueryHelpers 获取参数值
Id = QueryHelpers.ParseQuery(uri.Query).GetValueOrDefault("id");
StringValues extraTopping;
// QueryHelpers TryGetValue获取参数值
if (QueryHelpers.ParseQuery(uri.Query).TryGetValue("id", out extraTopping))
{
Id = System.Convert.ToString(extraTopping);
}
}
}配置路由参数获取参数值
将参数名声明为路由参数
使用 @page 指令指定将作为路由参数传递给组件的 URI 部分。 在组件的代码中,你可以像获取组件参数的值一样获取路由参数的值:
@page "/article/{id}"使用可选路由参数
这样的话如果没有id参数会找不到路由。如果id可以不传,那么可以使用可选路由参数:
@page "/article/{id?}"根据微软的建议,为可选参数设置默认值是很好的做法。
为路由参数指定类型
如果需要限制参数的类型,可以为路由参数指定类型:
@page "/article/{id:int?}"
@code {
[Parameter]
public int? Int{ get; set; }
}设置捕获全部路由参数
如果要同时获得几个同名参数的话可以设置捕获全部路由参数
@page "@page "/{*name}""
@code {
[Parameter]
public string? Name { get; set; }
}此时我们传递多个参数 https://localhost:7096/paul/mary/peter
获取的Name值为: paul/mary/peter
网友点评
提交
相关阅读
Blazor的5种render-mode的区别
Blazor使用内存中状态容器服务保存和验证登陆状态
.NET8 Blazor的Auto渲染模式
Blazor 与传统 ASP.NET MVC 的对比
前端开发有必要学习Blazor吗?
Blazor 与传统 MVC 对比详解:如何为你的 .NET 项目选择合适框架
.NET用Blazor的公司多吗?
Blazor ServerPrerendered模式OnInitialized{Async}执行两次
相关帖子
Blazor 路由参数报错 No writer was cached for the property 'MyId' on type 'BlazorApp2.Pages.Index'.
Blazor Error: Connection disconnected with error 'TypeError: Failed to fetch'.
魔兽世界WLK怀旧服盗贼命中多少达标?
如何识别 AI 生成内容?实用识别技巧与主流检测工具推荐
犯罪都市3 马东锡 高清百度网盘迅雷磁力bt下载
破墓 2024韩国恐怖电影 韩语中字高清 百度网盘 bt磁力下载
三番云机场测评:2026 三番云全面使用体验与加速性能分析
魔兽世界WLK怀旧服生存猎人天赋加点雕文输出手法