Angular2仅允许预定义查询参数。
创始人
2024-10-22 07:30:29
0

可以使用Angular的CanActivate守卫来实现这种约束。首先,定义一个预先定义的查询参数数组。然后,在路由配置中将其与CanActivate守卫对象一起使用,以确保只有在预定义的参数中存在时才可以进行路由。

以下是一个简单的示例:

创建一个名为“QueryParamGuard”的新服务,并使用路由配置将其添加到路由配置中:

import { Injectable } from '@angular/core';
import { CanActivate, ActivatedRouteSnapshot } from '@angular/router';

@Injectable()
export class QueryParamGuard implements CanActivate {
  predefinedParams = ['page', 'filter'];

  canActivate(route: ActivatedRouteSnapshot) {
    const queryParams = route.queryParams;
    const keys = Object.keys(queryParams);

    for (const key of keys) {
      if (!this.predefinedParams.includes(key)) {
        return false;
      }
    }

    return true;
  }
}

在路由配置中使用此守卫对象:

import { Routes } from '@angular/router';
import { QueryParamGuard } from './query-param.guard';

export const routes: Routes = [
  {
    path: '',
    component: HomeComponent,
    canActivate: [QueryParamGuard]
  },
  // ...
];

现在,在尝试在路由中使用未预定义的查询参数时,路由将被阻止,并且只有在指定的预定义参数中存在时才可以成功导航。

相关内容

热门资讯

第3分钟窍要!德扑之心免费透视... 第3分钟窍要!德扑之心免费透视(透视)一贯是有辅助下载(哔哩哔哩)该软件可以轻松地帮助玩家将德扑之心...
第七分钟阶段!hhpoker怎... 第七分钟阶段!hhpoker怎么破解(透视)竟然有辅助开挂(哔哩哔哩)该软件可以轻松地帮助玩家将hh...
九分钟秘籍!wepoker私人... 九分钟秘籍!wepoker私人局俱乐部辅助(透视)总是是有辅助下载(哔哩哔哩)1、这是跨平台的wep...
7分钟课程!wepoker究竟... 7分钟课程!wepoker究竟有没有透视(透视)切实是真的有辅助安装(哔哩哔哩)1、用户打开应用后不...
第三分钟教程书!wepoker... 第三分钟教程书!wepoker轻量版辅助(透视)果然有辅助教程(哔哩哔哩)该软件可以轻松地帮助玩家将...
六分钟大纲!wepoker插件... 六分钟大纲!wepoker插件辅助(透视)本来是有辅助透视(哔哩哔哩)运wepoker插件辅助辅助工...
第六分钟策略!拱趴大菠萝挂哪里... 第六分钟策略!拱趴大菠萝挂哪里(透视)好像是真的有辅助神器(哔哩哔哩)1、拱趴大菠萝挂哪里辅助软件下...
5分钟技法!wpk透视工作室(... 5分钟技法!wpk透视工作室(透视)切实是有辅助教程(哔哩哔哩)wpk透视工作室脚本下载中分为三种模...
8分钟阶段!wepoker透视... 8分钟阶段!wepoker透视脚本安卓(透视)其实有辅助下载(哔哩哔哩)1、wepoker透视脚本安...
3分钟法门!如何判断wpk辅助... 3分钟法门!如何判断wpk辅助软件的真假(透视)原来是真的有辅助教程(哔哩哔哩)1、起透看视 如何判...