加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Angular 2嵌套路由解析执行

发布时间:2020-12-17 07:28:12 所属栏目:安全 来源:网络整理
导读:例如,如果我有以下路线组织: const appRoutes: Routes = [ { path: "",component: AppComponent,resolve: { app: AppResolver },children: [ { path: "",component: NestedComponent,resolve: { subscribers: NestedResolver } } ] }]; 和以下解析器: expo
例如,如果我有以下路线组织:
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 router 3.0.0-rc.2

我知道这个问题很老了,以防万一有人偶然发现它(像我一样).

这是一个已知的错误,它已被修复.只需将您的路由器版本更新为高于或等于2.1.0的版本,您应该好好去.这里参考的是相关的issue on github和associated fix

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读