我正在使用最新的Angular CLI build(16),我试图延迟加载路由,但由于某种原因失败,我找不到任何新的问题或解决方案为了这。Angular 2没有提供RouterOutletMap的延迟加载
文件夹结构:
core.component.html:
<router-outlet></router-outlet>
core.component.ts:
import {NgModule} from '@angular/core';
import {BrowserModule} from '@angular/platform-browser';
import {RouterModule} from '@angular/router';
// Modules
import {AdminAreaModule} from './+admin-area';
// Services
import {GlobalsService, RegexService, UtilsService} from './shared';
// Main app component
import {CoreComponent} from './core.component';
@NgModule({
imports: [
BrowserModule,
// Feature modules
AdminAreaModule
],
exports: [
BrowserModule
],
declarations: [
CoreComponent
],
providers: [
GlobalsService,
RegexService,
UtilsService
],
bootstrap: [CoreComponent]
})
export class CoreModule {}
管理区域,router.module。 ts:
import {NgModule} from '@angular/core';
import {RouterModule} from '@angular/router';
// Global modules
import {ComponentsModule, SharedModule} from '../../shared';
// Lazy loaded modules
import {AdminAreaModule} from '../admin-area.module';
@NgModule({
imports: [
RouterModule.forChild([
{
path: 'admin',
loadChildren: 'app/+admin-area/admin-area.module#AdminAreaModule'
}
])
],
exports: [
RouterModule
]
})
export class AdminAreaRouterModule {}
管理-area.module.ts:
import {NgModule} from '@angular/core';
import {AdminAreaRouterModule} from './router';
import {ComponentsModule, SharedModule} from '../shared';
@NgModule({
imports: [
ComponentsModule,
SharedModule,
// Feature modules
AdminAreaRouterModule
],
exports: [
ComponentsModule,
SharedModule,
AdminAreaRouterModule
]
})
export class AdminAreaModule {}
这将引发一个错误:
Error in ./CoreComponent class CoreComponent - inline template:0:0 caused by: No provider for RouterOutletMap!
为什么会出现这个错误时,我清楚地在我core.component.ts
文件router-outlet
?
这只是给了'最大callstack超过':| – Chrillewoodz
基本上我所拥有的是网站的两部分,一个管理区和一个普通网站。我想''''''''''''''''''''''''''''''''''''''''''可以成为普通网站,'/所以我用自己的路由制作了两个模块。我是否懒惰加载核心模块中的'/'和'/ admin'?然后他们各自的孩子在自己的路由文件? – Chrillewoodz
@Chrillewoodz是的,你会在核心模块中延迟加载/和/管理,相应的孩子应该被捆绑在延迟加载的模块中。 – koningdavid