angular - Angular惰性路由忽略父路径
问题描述
我正在使用 Angular 6.1,并尝试使用延迟路由设置应用程序模块和功能模块(称为实体模块)。我想创建一个路由/entities/list,链接到我的实体模块中的一个组件。但我无法让这条路线工作。相反,当我导航到/list时,将显示该组件。为什么我的路由忽略了父“ /entities ”路径?
app.module.ts:
import {NgModule} from '@angular/core';
import {AppComponent} from './app.component';
import {AppRoutingModule} from './app-routing.module';
import {BrowserModule} from '@angular/platform-browser';
import {EntitiesModule} from './entities/entities.module';
@NgModule({
bootstrap: [AppComponent],
declarations: [AppComponent],
imports: [AppRoutingModule, BrowserModule, EntitiesModule],
providers: []
})
export class AppModule {}
应用程序路由.module.ts:
import {NgModule} from '@angular/core';
import {RouterModule, Routes} from '@angular/router';
const routes: Routes = [
{path: 'entities', loadChildren: './entities/entities.module#EntitiesModule'},
{path: '', redirectTo: '', pathMatch: 'full'}
];
@NgModule({
imports: [RouterModule.forRoot(routes)],
exports: [RouterModule]
})
export class AppRoutingModule {}
app.component.ts:
import {Component} from '@angular/core';
@Component({
selector: 'app-root',
template: 'app <router-outlet></router-outlet>'
})
export class AppComponent {}
实体/实体.module.ts:
import {NgModule} from '@angular/core';
import {EntitiesRoutingModule} from './entities-routing.module';
import {EntitiesComponent} from './entities.component';
@NgModule({
declarations: [EntitiesComponent],
imports: [EntitiesRoutingModule]
})
export class EntitiesModule {}
实体/实体-routing.module.ts:
import {NgModule} from '@angular/core';
import {Routes, RouterModule} from '@angular/router';
import {EntitiesComponent} from './entities.component';
const routes: Routes = [
{path: 'list', component: EntitiesComponent}
];
@NgModule({
imports: [RouterModule.forChild(routes)],
exports: [RouterModule]
})
export class EntitiesRoutingModule {}
实体/实体.component.ts:
import {Component} from '@angular/core';
@Component({
selector: 'app-entities',
template: 'entities'
})
export class EntitiesComponent {}
我还尝试使用以下方法在实体模块中定义路由,但组件仍将显示为导航到/list,而不是导航到/entities/list。
const routes: Routes = [
{
path: '', children: [
{path: 'list', component: EntitiesComponent}
]
}
];
我究竟做错了什么?任何帮助表示赞赏!
解决方案
您正在尝试进行延迟加载。但是,您正在进行急切加载。
app.module.ts
在行中:
进口:[AppRoutingModule,BrowserModule,EntitiesModule
],
正在加载实体模块。从那里删除它以进行延迟加载,它应该可以工作。
推荐阅读
- flutter - 使用列表视图时如何将小部件放置到页面底部?
- javascript - Creating a full screen popup window and updating the scroll bar
- reactjs - Duplicating authentication data between the store and localStorage
- javascript - 为什么我在 p5.js 中收到无限循环错误?
- c# - 如何在 settings.default 中保存自定义设置?
- python - Python dataframe rows contains multiple list of string search
- amazon-redshift - Redshift DROP TABLE never stops executing
- typescript - 如何在不锁定浏览器的情况下创建过滤器?
- javascript - 如何将参数预期为用户 ID?
- ios - 如何防止 TableView 崩溃?