Angular:Resolver即使在服务返回后也会延迟组件加载

时间:2017-11-03 06:28:12

标签: angular angular2-routing angular2-http angular2-resolve

我有一些数据必须在页面加载之前加载,我正在使用路由解析器来实现这一点。以下是我的代码。

服务:

getUsernamesAndBUs(): Observable<any> {
    return Observable.forkJoin(
      this.http.get('http://localhost:8080/BMSS/getBusinessUnit'),
      this.http.get('http://localhost:8080/BMSS/getAllUser'),
      this.http.get('http://localhost:8080/BMSS/getCountry'),
      this.http.get('http://localhost:8080/BMSS/getCurrency')
    );
  }

解析器:

import { Injectable } from '@angular/core';
import { Resolve, ActivatedRouteSnapshot } from '@angular/router';
import { AgreementDetailsService } from './agreement-details.service';
import { Observable } from 'rxjs/Observable';

@Injectable()
export class UsernamesAndBusResolveService implements Resolve<any> {

  constructor(private agreementDetailsService: AgreementDetailsService) { }

  resolve(route: ActivatedRouteSnapshot): Observable<any> {
    return this.agreementDetailsService.getUsernamesAndBUs();
  }
}

路由模块:

{
    path: 'agreement',
    canActivate: [CanActivateAuthGuardService],
    children: [
      {
        path: 'create',
        component: AgreementComponent,
        resolve: { usernamesAndBUs: UsernamesAndBusResolveService }
      }
    ]
  }

在路由到的组件中:

this.businessUnits = this.route.snapshot.data['usernamesAndBUs'][0];
this.users = this.route.snapshot.data['usernamesAndBUs'][1];
this.countries = this.route.snapshot.data['usernamesAndBUs'][2];
this.currencies = this.route.snapshot.data['usernamesAndBUs'][3];

在拦截器中:

intercept(httpRequest: HttpRequest<any>, httpHandler: HttpHandler): Observable<HttpEvent<any>> {
    if (!this.typeAheads.includes(httpRequest.url.split('/').pop())) {
      this.bmssLoaderService.start();
    } else {
      this.bmssLoaderService.stop();
    }


    return httpHandler.handle(httpRequest).do((httpEvent: HttpEvent<any>) => {
      if (httpEvent instanceof HttpResponse) {
        this.bmssLoaderService.stop();
      }
    }, (error: any) => {
      this.bmssLoaderService.stop();
    });
  }

我使用一个微调器(使用HttpInterceptor),在调用后端服务时显示,并在服务返回后消失。现在即使在后端服务返回后组件也需要很长时间才能加载,在微调器消失之后,用户仍然在同一页面上一段时间(大约10秒),然后再路由到目标页面。

我没有得到导致这种延迟的原因以及我错在哪里。请帮帮我。

0 个答案:

没有答案