在Angular2中,如何使用resolve和Promise在应用程序路由呈现页面之前等待从服务器加载数据

时间:2019-03-08 10:41:49

标签: angular typescript angular-routing

我正在研究Angular 6应用程序。我有从数据库加载动态路由的要求。为此,我要注入路由服务类(DynamicRoutingService),该类负责从数据库加载静态和动态路由,并添加app.module.ts-> RouterModule.forRoot(RouteCollection)。

在DynamicRoutingService类中,我正在使用Subscribe方法加载数据,我的问题是请求的URL页面在Subscribe方法获得http结果之前就已呈现,因此,应用程序抛出无效路由错误。

我碰巧使用决心并承诺解决此问题,但不确定我是否确实做到这一点,那是我需要帮助的地方

应用路由解析器

local-infile

app.component

Injectable()
export class AppRoutingResolver implements Resolve<any>{

constructor(
    private router: Router
){}

resolve(route: ActivatedRouteSnapshot):Promise<any> | boolean{
    return false;
 }
}

app.routing.module

export class AppComponent {

constructor(private routingService:DynamicRoutingService){
   routingService.initializeDynamicRoutes(); // call service to reload routes
}
}

DynamicRoutingService

@NgModule({
imports: [
  RouterModule.forRoot(RouteCollection)
 ],
 exports: [
  RouterModule
  ]
 })
  export class AppRoutingModule { 

 constructor(
 private router:Router
 ) { 
 }
}

DataService调用http查询

 @Injectable({
 providedIn: 'root'
 })

 export class DynamicRoutingService {

private dynamicRoutes: Route[] = [];
private waitToLoadRoutes: boolean = true;
private dynamicRoutesData: any;
private routeObject: any;
routeSubject: string = "survey";
static forEach: any;


constructor(
    private router: Router,
    private dynamicRoutesDataServices: DynamicRoutesDataServices
 ) { }

 public initializeDynamicRoutes() {
    this.loadDynamicRoutes();
 }


public loadDynamicRoutes(): Route[] {
    //LOADING DATA FROM DATABASE

this.dynamicRoutesDataServices.GetDynamicRoutesCollection(this.routeSubject)
        .subscribe((result: any) => {
            if (result) {
                this.dynamicRoutesData = result
                if (this.dynamicRoutesData) {
                    this.assembleDynamicRoutes();
                }
            }
        });

    return this.dynamicRoutes;
}

Http查询以调用API

export class DynamicRoutesDataServices{

constructor(
    private getDynamicRoutesQuery:GetDynamicRoutesQuery
){}

public GetDynamicRoutesCollection(routesSubject: string): any{
    this.getDynamicRoutesQuery.initialise(routesSubject);
    var result = this.getDynamicRoutesQuery.execute();
    return result;
 }
}

1 个答案:

答案 0 :(得分:2)

我不确定您是否在这里使用正确的方法来加载动态路由。角解析器是为指定路由预取数据的助手。

示例1:

 RouterModule.forRoot([
      {
        path: 'team/:id',
        component: TeamComponent,
        resolve: {
          team: TeamResolver
        }
      }
    ])

解析器将团队的信息存储在ActivatedRoute数据属性的team属性中。因此,您需要将其附加到现有路由。

https://angular.io/api/router/Resolve

https://codeburst.io/understanding-resolvers-in-angular-736e9db71267