Angular:如果未提供子参数id,则重定向到父级。
创始人
2024-11-01 23:00:26
0

在Angular中,可以使用路由守卫来实现重定向到父级的功能。下面是一个示例解决方法:

首先,创建一个路由守卫服务,例如AuthGuardService

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

@Injectable({
  providedIn: 'root'
})
export class AuthGuardService implements CanActivate {

  constructor(private router: Router) { }

  canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean | UrlTree {
    const id = route.params.id;

    if (!id) {
      const parent = route.parent;

      if (parent) {
        const parentId = parent.params.id;
        return this.router.parseUrl(`/parent/${parentId}`);
      }
    }

    return true;
  }
}

然后,在路由配置中应用这个路由守卫:

import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { AuthGuardService } from './auth-guard.service';

const routes: Routes = [
  {
    path: 'parent/:id',
    canActivate: [AuthGuardService],
    children: [
      // 子路由配置
    ]
  }
];

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

在上面的示例中,AuthGuardService中的canActivate方法会检查路由参数中是否提供了id。如果没有提供,则会从父级路由中获取id并重定向到父级路由。

请注意,上述示例中的路由配置假设存在一个parent/:id的父级路由,你需要根据实际情况进行相应的调整和修改。

相关内容

热门资讯

透视解密"wepok... 透视解密"wepoker有透视功能吗"本来是有辅助攻略(哔哩哔哩)wepoker有透视功能吗脚本下载...
透视必备"wepok... 透视必备"wepoker私人局透视插件"一直是有辅助攻略(哔哩哔哩)1、wepoker私人局透视插件...
透视普及"哈糖大菠萝... 透视普及"哈糖大菠萝免费辅助器"总是真的是有辅助神器(哔哩哔哩)1、该软件可以轻松地帮助玩家将哈糖大...
透视推荐"竞技联盟辅... 透视推荐"竞技联盟辅助插件"好像真的是有辅助挂(哔哩哔哩)1、任何竞技联盟辅助插件透视是真的假的的玩...
透视关于"hhpok... 透视关于"hhpoker万能辅助器"切实是真的辅助攻略(哔哩哔哩)hhpoker万能辅助器脚本下载中...
透视详细"wpk模拟... 透视详细"wpk模拟器是什么"其实存在有辅助神器(哔哩哔哩)1、完成wpk模拟器是什么有辅助插件,帮...
透视解密"hhpok... 透视解密"hhpoker真能买到挂吗"竟然是有辅助挂(哔哩哔哩)1、下载好hhpoker真能买到挂吗...
透视专业"红龙pok... 透视专业"红龙poker辅助平台"好像存在有辅助软件(哔哩哔哩)暗藏猫腻,小编详细说明红龙poker...
透视曝光"福建大菠萝... 透视曝光"福建大菠萝万能辅助器"果然有辅助攻略(哔哩哔哩)1、玩家可以在福建大菠萝万能辅助器线上大神...
透视解密"wepok... 透视解密"wepoker买钻石有用吗"一直真的有辅助app(哔哩哔哩)1、玩家可以在wepoker买...