模块A是这样定义的
@NgModule({
providers: [AService],
declarations: [ TitleComponent ],
exports: [ TitleComponent ],
})
export class A {}
如果有惰性模块lazyModule导入模块A,那么会生成子注入器将AService重新生成
这时如果想将AService变成全局唯一的,那么在lazyModule导入的时候就不要导入providers而只导入TitleComponent
forRoot这时就有用武之地了
改写A
@NgModule({ providers: [], declarations: [ TitleComponent ], exports: [ TitleComponent ], }) export class A { static forRoot() { return {ngModule: A, providers: [AService]}; } }
在appModule中使用A.forRoot导入A模块
@NgModule({
imports: [A.forRoot()]
})
export class AppModule {}
在lazyModule中正常导入A模块
@NgModule({
imports: [A]
})
export class LazyModule{}
本文介绍如何在Angular项目中实现模块A中的AService作为全局唯一实例,避免懒加载模块导致的服务重复创建。通过重构模块A并利用forRoot静态方法,在AppModule中集中配置全局服务。

346

被折叠的 条评论
为什么被折叠?



