我有一个类似这样的 URL:
base_path/some_path?elementId=33203
基本上,用户可以并且通常通过在浏览器中粘贴上述链接来导航到该路径。我需要在组件之前加载该组件的数据,因此我开始阅读 Angular 路由教程,特别是旨在实现我所拥有的确切难题的解析器服务。所以我创建了一个解析器服务,例如:
resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<SomeObject> {
let loanId = route.queryParams['elementId'];
if (isNil(loanId)) {
return null;
}
return this.service.getElementById(elementId)
.subscribe(response => {
//response is JSON
return Observable.of(response);
}
else {
return null;
}
});
}
这个解析类现在添加到 app.routing.module.ts 中,例如:
{ path: 'base_path/some_path', component: SomeComponent,
resolve : {
someObject: SomeObjectResolver
}
}
并在我的component.ts文件中进行相应的修改,如:
ngOnInit() {
this.route.data.subscribe((data: { someObject: SomeObject}) => {
});
}
我在解析器和组件文件中设置了调试断点。当我访问 URI:base_path/some_path?elementId=33203
时,它首先访问了解析器,但是由于解析器调用了服务(这反过来又调用了对服务器获取数据的 ajax 调用),它然后简单地继续到组件,并调用 ngOnInit 函数,tryin在 (data: { someObject: SomeObject}) 上调用订阅函数
但是, someObject 尚不可用,因此它会引发错误并重定向。
我错过了什么?resolve 函数不应该在调用它之前显式加载它的组件的数据吗?