ngOninit компонента получает удар до того, как служба getReport возвращает данные. Это не дожидается разрешения службы.Угловые 2 компоненты загружаются до того, как маршрут будет разрешен.
маршрутизации:
@Injectable()
class ReportResolver implements Resolve<any> {
constructor(private reportsService: ReportsService) {
}
resolve(
route: ActivatedRouteSnapshot,
state: RouterStateSnapshot
): any {
this.reportsService.GetReport(route.params["id"]).subscribe((data: any) => {
return data;
});
}}
const appRoutes: Routes = [
{
path: "reports/:id",
component: TabularReportsFachadeComponent,
resolve: { report: ReportResolver }
},
{
path: "",
component: DashboardComponent
},];
обслуживание:
GetReport(id: any): Observable<any> {
return this._http.get("api/reports/?" + id).map(res => res.json());
}
компонент:
ngOnInit(): void {
debugger
this.report = this.route.snapshot.data["report"].data;
}
компоненты ngOninit становится хит до getReport
Я удалил подписку, и это сработало. Благодаря! – janIreal23
Рад слышать :) Спасибо за отзыв. –