Есть один модуль, который содержит все компоненты, и один модуль маршрута.
Модуль маршрутизации:
import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';
import { UserComponent } from './user/user.component';
import { AdminComponent } from './admin/admin.component';
import { AdminDishesComponent } from './admin/adminDishes/adminDishes.component';
import { AdminCategoriesComponent } from './admin/adminCategories/adminCategories.component';
const appRoutes: Routes = [
{
path: '',
pathMatch: 'full',
redirectTo: 'user'
},
{
path: 'user',
component: UserComponent
},
{
path: 'admin',
component: AdminComponent,
children: [
{
path: 'dishes',
component: AdminDishesComponent
},
{
path: 'categories',
component: AdminCategoriesComponent
}
]
}
];
@NgModule({
imports: [
RouterModule.forRoot(appRoutes)
],
declarations: [],
exports: [
RouterModule
]
})
export class RoutingModule { }
Корневой компонент:
<a routerLink="/admin">Admin control panel</a>
<router-outlet></router-outlet>
Компонент администратора:
<ul id="leftMenu">
<li><a routerLink="/dishes">Dishes</a></li>
<li><a routerLink="/categories">Categories</a></li>
</ul>
<div id="adminContent">
<router-outlet></router-outlet>
</div>
Пожалуйста
Ссылки должны быть такими:
http://localhost:4200/admin/categories
Но Angular дайте мне ссылку:
http://localhost:4200/categories
Если я ввожу в адресную строку нужный мне адрес, все работает.