Angular 7 路由 - 如何确保所有路由都以 :gymId 参数为前缀
创始人
2024-10-16 19:00:54
0

要确保所有路由都以 :gymId 参数为前缀,可以使用 Angular 7 的路由配置和路由守卫来实现。以下是一种解决方法:

  1. 首先,在路由模块中定义一个常量,用于存储 :gymId 参数的前缀:
export const GYM_ID_PREFIX = 'gymId';
  1. 在路由配置中,使用 GYM_ID_PREFIX 常量作为路由路径的前缀。例如:
import { GYM_ID_PREFIX } from './constants';

const routes: Routes = [
  { path: `${GYM_ID_PREFIX}/:gymId/dashboard`, component: DashboardComponent },
  { path: `${GYM_ID_PREFIX}/:gymId/users`, component: UsersComponent },
  // 其他路由配置
];

这样,所有以 :gymId 参数为前缀的路由都会匹配对应的组件。

  1. 创建一个路由守卫,用于验证路由是否以 :gymId 参数为前缀。如果不是,则重定向到以 :gymId 参数为前缀的路由。
import { Injectable } from '@angular/core';
import { CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot, Router } from '@angular/router';
import { GYM_ID_PREFIX } from './constants';

@Injectable({
  providedIn: 'root'
})
export class GymIdGuard implements CanActivate {
  constructor(private router: Router) {}

  canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
    const url: string = state.url;
    const segments: string[] = url.split('/');

    // 检查路由是否以 `:gymId` 参数为前缀
    if (segments.includes(GYM_ID_PREFIX)) {
      return true;
    }

    // 如果不是以 `:gymId` 参数为前缀,则重定向到以 `:gymId` 参数为前缀的路由
    this.router.navigate([`${GYM_ID_PREFIX}/${segments[1]}/${segments.slice(2).join('/')}`]);
    return false;
  }
}
  1. 在路由模块中使用 GymIdGuard 路由守卫来保护需要以 :gymId 参数为前缀的路由:
import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { GymIdGuard } from './gym-id.guard';

const routes: Routes = [
  { path: `${GYM_ID_PREFIX}/:gymId/dashboard`, component: DashboardComponent, canActivate: [GymIdGuard] },
  { path: `${GYM_ID_PREFIX}/:gymId/users`, component: UsersComponent, canActivate: [GymIdGuard] },
  // 其他路由配置
];

@NgModule({
  imports: [RouterModule.forChild(routes)],
  exports: [RouterModule]
})
export class GymRoutingModule { }

这样,只有当路由以 :gymId 参数为前缀时,才能访问对应的组件。如果路由不是以 :gymId 参数为前缀,则会重定向到以 :gymId 参数为前缀的路由。

相关内容

热门资讯

九分钟辅助!小程序财神十三张祈... 九分钟辅助!小程序财神十三张祈福,一贯真的是有辅助挂(真的有挂)1、小程序财神十三张祈福破解器简单,...
三分钟辅助!创游世界辅助器,好... 三分钟辅助!创游世界辅助器,好像真的是有辅助技巧(竟然有挂)创游世界辅助器能透视中分为三种模型:创游...
七分钟辅助!约局吧作弊,原来是... 七分钟辅助!约局吧作弊,原来是真的有辅助挂(有挂规律)1、约局吧作弊公共底牌简单,约局吧作弊透视插件...
两分钟辅助!微信小程序游戏修改... 两分钟辅助!微信小程序游戏修改器,果然有辅助挂(果真有挂)1、微信小程序游戏修改器破解器简单,微信小...
第7分钟辅助!边锋干橙眼辅助器... 第7分钟辅助!边锋干橙眼辅助器名称,切实真的是有辅助软件(有挂规律)1.边锋干橙眼辅助器名称 选牌创...
5分钟辅助!打两圈绝对有辅助,... 5分钟辅助!打两圈绝对有辅助,确实存在有辅助挂(有挂存在)打两圈绝对有辅助是不是有人用挂微扑克wpk...
第二分钟辅助!宝宝吃吃吃游戏辅... 第二分钟辅助!宝宝吃吃吃游戏辅助,原来是真的有辅助方法(果真有挂)1)宝宝吃吃吃游戏辅助免费钻石:进...
第1分钟辅助!邯郸胡乐修改器,... 第1分钟辅助!邯郸胡乐修改器,切实存在有辅助神器(有挂方略)邯郸胡乐修改器是不是有人用挂微扑克wpk...
四分钟辅助!泸州家乡大二辅助,... 四分钟辅助!泸州家乡大二辅助,本来是真的有辅助插件(有挂方法)1、下载好泸州家乡大二辅助脚本下载之后...
3分钟辅助!湖北逍遥辅助,果然... 3分钟辅助!湖北逍遥辅助,果然是真的有辅助神器(确实有挂)所有人都在同一条线上,像星星一样排成一排,...