Angular路由参数默认值不起作用的问题
创始人
2024-10-28 01:00:34
0
  1. 使用 || 运算符:

在定义路由参数时,可以使用 || 运算符来给特定参数设置默认值。例如:

const routes: Routes = [ { path: 'user/:id', component: UserProfileComponent }, { path: 'user/:id/:name', component: UserProfileComponent }, { path: '**', redirectTo: 'home' } ];

在上述代码中,用户的 ID 和名称都是路由参数,默认情况下,如果未指定名称,名称将为空字符串。通过使用 || 运算符,我们可以将名称设置为“未知”,如下所示:

const routes: Routes = [ { path: 'user/:id', component: UserProfileComponent }, { path: 'user/:id/:name', component: UserProfileComponent, data: { name: 'unknown' || params.name } }, { path: '**', redirectTo: 'home' } ];

  1. 使用 ActivatedRoute:

我们还可以使用 ActivatedRoute 来获取当前路由参数并设置默认值。在组件中,我们可以注入 ActivatedRoute 并使用 Snapshot 获取当前参数。例如:

import { Component, OnInit } from '@angular/core'; import { ActivatedRoute } from '@angular/router';

@Component({ selector: 'app-user-profile', templateUrl: './user-profile.component.html', styleUrls: ['./user-profile.component.css'] }) export class UserProfileComponent implements OnInit {

id: string; name: string;

constructor(private route: ActivatedRoute) { }

ngOnInit() { this.id = this.route.snapshot.paramMap.get('id'); this.name = this.route.snapshot.paramMap.get('name') || 'unknown'; }

}

在上述代码中,ngOnInit() 方法获取当前路由参数,并将名称设置为“未知”,如果没有指定名称。这样就可以确保默认值始终起作用。

相关内容

热门资讯

黑科技游戏!wepoke透视挂... 黑科技游戏!wepoke透视挂靠谱(ai代打)从来真的有挂(有挂辅助)-哔哩哔哩1、不需要AI权限,...
黑科技苹果版!wepower外... 黑科技苹果版!wepower外挂检测方法(黑科技ai)好像是有挂(有挂稳赢)-哔哩哔哩;亲真的是有正...
黑科技安装!线上德州辅助工具有... 黑科技安装!线上德州辅助工具有哪些(智能ai)本然是有挂(有挂俱乐部)-哔哩哔哩关于线上德州辅助工具...
黑科技脚本!wepower发牌... 黑科技脚本!wepower发牌机制讲解(智能ai)素来是有挂(有挂自建房)-哔哩哔哩;亲真的是有正版...
黑科技真的!线上微扑克代打(a... 黑科技真的!线上微扑克代打(ai代打)起初有挂(有挂神器)-哔哩哔哩;1.线上微扑克代打 ai辅助创...
黑科技数据!aapoker 辅... 黑科技数据!aapoker 辅助工具(ai代打)其实是有挂(有挂最新款)-哔哩哔哩;1.aapoke...
黑科技苹果版!微扑克辅助(透视... 黑科技苹果版!微扑克辅助(透视)本来有挂(有挂私人房)-哔哩哔哩是一款可以让一直输的玩家,快速成为一...
黑科技安卓版!wepoke真的... 黑科技安卓版!wepoke真的有挂吗(ai辅助)从来存在有挂(有挂德州版)-哔哩哔哩1、点击下载安装...
黑科技免费!aapoke辅助工... 黑科技免费!aapoke辅助工具存在吗(辅助挂)一向是有挂(有挂稳赢)-哔哩哔哩准备好在aapoke...
黑科技有挂!微扑克代打是真的吗... 黑科技有挂!微扑克代打是真的吗(黑科技)都是存在有挂(有挂下载)-哔哩哔哩1、不需要AI权限,帮助你...