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() 方法获取当前路由参数,并将名称设置为“未知”,如果没有指定名称。这样就可以确保默认值始终起作用。

相关内容

热门资讯

透视系统(WPk)透视挂使用教... 您好,这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中打牌都...
透视玄学(wPk)ai辅助(黑... 透视玄学(wPk)ai辅助(黑科技)ai辅助实战效果(一直真的是有挂);致您一封信;亲爱玩家:《透明...
透视实锤(wpK)最新黑科技(... 您好,这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中打牌都...
详细辅助(微扑克)职业代打(辅... 详细辅助(微扑克)职业代打(辅助挂)有辅助挂吗(总是真的有挂)1、很好的工具软件,可以解锁游戏的ai...
透视讲解(WPK)俱乐部黑科技... 透视讲解(WPK)俱乐部黑科技(黑科技)辅助(本来是有挂);无聊就玩这款真的有辅助,无限炸弹无限金币...
黑科技辅助挂(WEPOKE)辅... 黑科技辅助挂(WEPOKE)辅助多久会检测到(黑科技)透明黑科技(好像存在有挂)(1)黑科技辅助挂(...
黑科技工具(WePoKer)用... 黑科技工具(WePoKer)用模拟器(黑科技)黑科技辅助挂(好像是真的有挂)是一款可以让一直输的玩家...
了解辅助(微扑克)ai辅助(辅... 了解辅助(微扑克)ai辅助(辅助挂)辅助插件挂(切实是有挂);了解辅助(微扑克)ai辅助(辅助挂)辅...
透视ai代打(wpK)有透视辅... 透视ai代打(wpK)有透视辅助吗(黑科技)透视辅助有病毒(好像是有挂)1、ai辅助优化,发牌逻辑科...
黑科技安卓版(wEPoke)有... 黑科技安卓版(wEPoke)有插件吗(黑科技)有插件(一直是真的有挂)1、构建自己的微扑克辅助插件;...