给定以下模块,我如何创建路由,以便当应用程序加载此模块时,它将路由到CComponent
并AComponent
加载到命名的路由器出口search-results
app.module.ts
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { RouterModule } from '@angular/router';
import { AComponent } from './a.component';
import { BComponent } from './b.component';
import { CComponent } from './c.component';
@NgModule({
declarations: [
AComponent,
BComponent,
CComponent
],
imports: [
BrowserModule,
RouterModule.forRoot([
{
path: '',
pathMatch: 'prefix',
component: CComponent,
children: [
{
path: 'a',
component: AComponent,
outlet: 'search-results'
},
{
path: 'b',
component: BComponent,
outlet: 'search-results'
}
]
])
],
providers: [],
bootstrap: [CComponent]
})
export class AppModule {}
a.component.ts
import { Component } from '@angular/core';
@Component({
selector: 'a-component',
template: `
<div class="tabs row">
<h3 [routerLink]="[{ outlets: { 'search-results': ['a'] } }]" class="tab" routerLinkActive="active">
A
</h3>
<h3 [routerLink]="[{ outlets: { 'search-results': ['b'] } }]" class="tab" routerLinkActive="active">
B
</h3>
</div>
<router-outlet name="search-results"></router-outlet>
`
})
export class AComponent {
}
我在路线上尝试了许多不同的东西:
使用上述配置,页面会加载,但AComponent
不会加载到屏幕上。
如果我更新CComponent
为具有以下内容:
export class CComponent {
constructor(
private route: ActivatedRoute,
private router: Router
) {
router.navigate(
[
{
outlets: {
'search-results': ['a']
}
}
], { relativeTo: route });
}
}
然后一切似乎都正常,但是必须在父元素的构造函数中触发该导航似乎是错误的。
如果我更新子路由并替换{ path: 'a', component: AComponent, outlet: 'search-results' }
为{ path: '', component: AComponent, outlet: 'search-results' }
,路由器似乎在插座中正确加载了该组件,但该routerLinkActive
指令似乎没有生效,因为active
该类未添加到第一个 h3 并且更新routerLink
tooutlets: { 'search-results': ['a'] }
没有导航到AComponent
后允许导航回BComponent
。
我在上面尝试了许多变体,但都没有成功。
有没有办法配置路由,以便默认路由将加载CComponent
到主要的未命名router-outlet
和AComponent
命名的search-results
路由器插座中?