在使用Angular 5进行懒加载时,需要先创建一个共享模块,该模块包含所有要共享的组件、指令和管道。然后,将该共享模块导入到需要使用相同组件和服务的组件中。
例如,在创建共享模块shared.module.ts中,可以像下面这样定义:
import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { SharedComponent } from './shared.component';
@NgModule({
imports: [CommonModule],
declarations: [SharedComponent],
exports: [SharedComponent]
})
export class SharedModule {}
在要使用享共模块的特性模块中(例如app.module.ts),可以像下面这样导入共享模块:
import { SharedModule } from './shared/shared.module';
@NgModule({
imports: [SharedModule],
declarations: [AppComponent],
bootstrap: [AppComponent]
})
export class AppModule { }
同样,在要使用共享模块的懒加载模块中,也需要导入该共享模块。例如,如果要在lazy.module.ts中使用共享模块,可以这样定义:
import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { RouterModule } from '@angular/router';
import { LazyComponent } from './lazy.component';
import { SharedModule } from '../shared/shared.module';
@NgModule({
imports: [CommonModule, RouterModule.forChild([{
path: '',
component: LazyComponent
}]), SharedModule],
declarations: [LazyComponent]
})
export class LazyModule {}
在这个示例中,导入了共享模块并将其添加到imports数组中。
如果仍然无法解决问题,可以尝试在tsconfig.json文件中添加一行'allowSyntheticDefaultImports: true”。例如:
{
"compilerOptions": {
"allowSyntheticDefaultImports": true,
...
}
}
以上方法可以解决Angular 5懒加载不起作用和共享模块不起作用的问题。