在Angular 9中,可以使用子布局组件和页面内容的路由出口来实现多个路由出口。下面是一个示例解决方法:
首先,创建一个父布局组件(parent-layout.component.html)和一个子布局组件(child-layout.component.html)。
parent-layout.component.html:
Parent Layout
child-layout.component.html:
Child Layout
接下来,创建两个页面组件(header.component.html和sidebar.component.html)用于在不同的路由出口中显示。
header.component.html:
This is the header component
sidebar.component.html:
This is the sidebar component
然后,在app-routing.module.ts文件中配置路由。
app-routing.module.ts:
import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { ParentLayoutComponent } from './parent-layout.component';
import { ChildLayoutComponent } from './child-layout.component';
import { HeaderComponent } from './header.component';
import { SidebarComponent } from './sidebar.component';
const routes: Routes = [
{
path: '',
component: ParentLayoutComponent,
children: [
{
path: '',
component: ChildLayoutComponent,
children: [
{ path: '', component: HomeComponent },
{ path: 'about', component: AboutComponent }
]
}
]
},
{ path: 'header', outlet: 'header', component: HeaderComponent },
{ path: 'sidebar', outlet: 'sidebar', component: SidebarComponent }
];
@NgModule({
imports: [RouterModule.forRoot(routes)],
exports: [RouterModule]
})
export class AppRoutingModule { }
最后,在app.component.html中使用带有命名路由出口的router-outlet。
app.component.html:
现在,当你导航到不同的路由时,父布局组件和子布局组件以及页面组件将会显示在相应的路由出口中。
希望这个示例可以帮助你理解如何在Angular 9中实现子布局组件和页面内容的路由出口。
上一篇:Angular 9 - 转换响应