Angular 2嵌套路由解析执行

10

例如,如果我有以下路由组织:

const appRoutes: Routes = [
    {
        path: "",
        component: AppComponent,
        resolve: {
            app: AppResolver
        },
        children: [
            {
                path: "",
                component: NestedComponent,
                resolve: {
                    subscribers: NestedResolver
                }
            }
        ]
    }
];

以及以下解析器:

export class AppResolver implements Resolve<any> {
    constructor(private appService: AppService) {}
    resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<any> {
        return this.appService.getAppData();
    }
}
export class NestedResolver implements Resolve<any> {
    constructor(private nestedService: NestedService) {}
    resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<any> {
        console.log(route.parent.data); //when this is executed route.parent.data is empty :(
        return this.nestedService.getNestedData();
    }
}

在应用程序引导后,NestedResolver和AppResolver将首先执行并并行发出它们的请求。

我们能否更改代码并实现NestedResolver等待AppResolver解析并访问AppResolver解析的数据?

Angular 2 RC6,Angular路由器3.0.0-rc.2


1
你能找到这个问题的答案吗? - Daniel Shin
1个回答

4
我知道这个问题很老了,但以防万一有人遇到类似的问题(就像我一样)。
这是一个已知的 bug,现在已经修复。只需将路由器版本更新到 2.1.0 或更高版本,您就可以使用了。供参考,这里是相关的 github 问题链接修复链接

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接