我希望我的主页为不同的角色加载不同的模块
const routes: Routes = [
{
path: 'login',
component: LoginComponent,
},
{ path: '', loadChildren: './dashboard/dashboard.module#DashboardModule', canLoad: [AuthGuard], canActivate: [AuthGuard], },
{
path: '',
loadChildren: './dashboard/dashboard.module#DashboardModule',
canActivate: [true]
},
]
AuthGuard 在这里
canActivate(
next: ActivatedRouteSnapshot,
state: RouterStateSnapshot
): Observable<boolean> | Promise<boolean> | boolean {
if (localStorage.getItem('ISTRAINER') === Role.Trainer
&& next.routeConfig.loadChildren === './dashboard/dashboard.module#DashboardModule') {
return true;
}
return false;
}
canLoad(route: Route): boolean {
return false;
}
当 canLoad: [AuthGuard] 返回 false 路由器不检查下一条路由时
或者有没有办法根据 Route 改变 loadChildren
实际上,我想在登录时说,如果学生角色在路线“仪表板”上登录,则在“仪表板”或“”学生模块上加载,或者如果在“仪表板”路线上登录教练角色,则在“”教练模块加载或如果管理员角色已登录,则加载“”管理模块