Angular路由器.navigate在canActivate()中不适用于子路由
创始人
2024-10-28 02:32:57
0

这是因为当使用navigate方法时,路由守卫会阻止导航到未激活的子路由。为了解决这个问题,我们需要使用路由器的navigateByUrl方法来导航到子路由。

以下是示例代码:

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

@Injectable()
export class AuthGuard implements CanActivate {

  constructor(private router: Router, private route: ActivatedRoute) {}

  canActivate() {
    if (isAuthenticated()) {
      return true;
    } else {
      // Navigate to login page with the current URL as a query string parameter
      this.router.navigateByUrl('/login?returnUrl=' + this.route.snapshot.url.join('/'));
      return false;
    }
  }
}

在这个示例中,我们使用了navigateByUrl方法来导航到/login子路由,同时将当前URL作为查询字符串参数一起传递。这样,用户在成功登录后将返回之前的URL。

我们需要确保在定义路由时将子路由的定义放在父路由的后面,以确保子路由成功地激活。例如:

const appRoutes: Routes = [
  { path: '', component: HomeComponent },
  { path: 'login', component: LoginComponent },
  { path: 'dashboard', component: DashboardComponent, canActivate: [AuthGuard], children: [
    { path: 'profile', component: ProfileComponent }
  ]},
  { path: '**', component: PageNotFoundComponent }
];

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

在这个例子中,子路由/profile是由父路由/dashboard激活的。

相关内容

热门资讯

9分钟了解!玉兔追月有挂吗!一... 9分钟了解!玉兔追月有挂吗!一直是有辅助app(有挂解惑)-哔哩哔哩1、完成玉兔追月有挂吗有辅助插件...
5分钟了解!兴动互娱辅助工具下... 5分钟了解!兴动互娱辅助工具下载!果然有辅助软件(有挂神器)-哔哩哔哩1、兴动互娱辅助工具下载有没有...
第9分钟了解!新九天辅助!切实... 第9分钟了解!新九天辅助!切实是有辅助插件(有挂头条)-哔哩哔哩1、点击下载安装,新九天辅助脚本分类...
第八分钟了解!决战卡五星游戏辅... 第八分钟了解!决战卡五星游戏辅助器!果然存在有辅助攻略(有挂总结)-哔哩哔哩;1、第八分钟了解!决战...
3分钟了解!蜀渝牌乐汇辅助!果... 3分钟了解!蜀渝牌乐汇辅助!果然真的有辅助方法(有挂辅助)-哔哩哔哩暗藏猫腻,小编详细说明蜀渝牌乐汇...
第六分钟了解!朋友圈app辅助... 第六分钟了解!朋友圈app辅助软件!一直是有辅助攻略(果真有挂)-哔哩哔哩1、朋友圈app辅助软件模...
9分钟了解!同乡游有辅助软件吗... 9分钟了解!同乡游有辅助软件吗!原来一直总是有辅助插件(有挂方法)-哔哩哔哩1、起透看视 同乡游有辅...
七分钟了解!牌乐们黑科技试用!... 七分钟了解!牌乐们黑科技试用!总是存在有辅助技巧(有挂辅助)-哔哩哔哩牌乐们黑科技试用辅助器是一种具...
第七分钟了解!微信老友广东辅助... 第七分钟了解!微信老友广东辅助器!好像存在有辅助插件(有挂实锤)-哔哩哔哩1、许多玩家不知道微信老友...
九分钟了解!欢乐情怀脚本辅助器... 九分钟了解!欢乐情怀脚本辅助器!好像存在有辅助攻略(有挂存在)-哔哩哔哩1、超多福利:超高返利,海量...