Kon*_*nou 6 angular-services angular angular-guards
我有一个像这样导航的组件
this.router.navigate(['results'], { state });
Run Code Online (Sandbox Code Playgroud)
一旦到了那里,我就获取了构造函数中的数据
constructor(private router: Router) {
const { state } = this.router.getCurrentNavigation().extras;
}
Run Code Online (Sandbox Code Playgroud)
我想放置一个警卫来检查此数据是否存在,否则导航到其他地方
@Injectable()
export default class RouteHasDataGuard implements CanActivate {
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
return !!state.root.data;
}
}
Run Code Online (Sandbox Code Playgroud)
但这不起作用。你能帮我吗?
不要在保护构造函数中读取额外内容。阅读 canActivate() 方法中的附加内容。
@Injectable()
export default class RouteHasDataGuard implements CanActivate {
constructor(private router: Router) {}
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
const { state } = this.router.getCurrentNavigation().extras;
return !!state.root.data;
}
}
Run Code Online (Sandbox Code Playgroud)
您可以这样访问状态:
@Injectable()
export default class RouteHasDataGuard implements CanActivate {
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
return !!window.history.state;
}
}
Run Code Online (Sandbox Code Playgroud)