1
getReportサービスがデータを返す前に、コンポーネントのngOninitがヒットしています。サービスが解決されるのを待っていません。経路が解決される前に角度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;
}
getReport
サブスクライブを削除して機能しました。ありがとう! – janIreal23
嬉しいことに:)フィードバックに感謝します。 –