问题1:组件oninit函数使用router.data.subscribe获取数据和父数据。
为什么可以得到父数据?
我在路由器文档中找不到信息。angular2路由器
问题2:为什么无法获取root父数据?在 app-router.module.ts 我定义了
数据:{pageTitle: 'youare', test:123213213},
我无法在 CrisisListComponent 中获取数据。
应用路由器.module.ts
const routes: Routes = [
{path: '', redirectTo: 'login', pathMatch: 'full'},
{path: 'login', component: LoginPage},
{
path: ':id',
component: MainLayoutComponent,
data: {pageTitle: 'youare', test:123213213},
children: [
{
path: 'personalcenter',
loadChildren: 'app/personalcenter/personal-center.module#PersonalCenterModule',
data: {pageTitle: 'personalcenter'}
},
{
path: 'crisis-center',
loadChildren: 'app/crisis-center/crisis-center.module#CrisisCenterModule',
data: { preload: true }
},
]
危机中心路由.module.ts
const crisisCenterRoutes: Routes = [
{
path: '',
component: CrisisCenterComponent,
data:{you:"are"},
children: [
{
path: '',
component: CrisisListComponent,
children: [
{
path: ':id',
component: CrisisDetailComponent,
canDeactivate: [CanDeactivateGuard],
resolve: {
crisis: CrisisDetailResolver
}
},
{
path: '',
component: CrisisCenterHomeComponent
}
]
}
]
}
];
危机列表.component.ts
export class CrisisListComponent implements OnInit {
constructor(
private service: CrisisService,
private route: ActivatedRoute,
private router: Router
) {}
ngOnInit() {
this.route.data.subscribe(data=>{
console.log("asdfsadfsadf"+JSON.stringify(data));
});
}
}
在 CrisisListComponent ,打印日志:"asdfsadfsadf{"preload":true,"you":"are"}"