Angularprovide的顺序问题。
创始人
2024-10-29 01:30:48
0

为Angular provide指定正确的顺序,并使用forwardRef来解决循环引用的问题。

Angular应用中,provide的顺序非常关键。如果Angular服务的提供者提前生成,那么所有依赖它的组件都将收到该服务实例的相同实例,即使它们自己也提供了服务。 这种问题可以通过指定提供程序的正确顺序来解决。在定义组件时,需要在其模块后面定义其provide。

示例代码:

// 定义服务 @Injectable() export class MyService {}

// 定义模块 @NgModule({ providers: [ MyService, { provide: SomeToken, useClass: SomeClass }, ... ] }) export class MyModule {}

// 定义组件 @Component({ selector: 'my-component', template:

MyComponent

, providers: [ { provide: SomeToken, useClass: SomeOtherClass }, MyService ] }) export class MyComponent {}

在上面的示例中,MyService必须在SomeToken和其他提供者之后定义,以确保其他提供者不会覆盖它。

如果服务之间存在循环依赖性,可以使用forwardRef来解决。

示例代码:

// 定义服务1 @Injectable() export class Service1 { constructor(@Inject(forwardRef(() => Service2)) private service2: Service2) {} }

// 定义服务2 @Injectable() export class Service2 { constructor(@Inject(forwardRef(() => Service1)) private service1: Service1) {} }

// 定义模块 @NgModule({ providers: [ Service1, Service2 ] }) export class MyModule {}

在上面的示例中,使用forwardRef来让Service1和Service2之间的循环依赖正确工作。

相关内容

热门资讯

七分钟开挂!潮友会鱼虾蟹破解,... 七分钟开挂!潮友会鱼虾蟹破解,丫丫老陕开挂,系统教程-2026最新版本1、上手简单,内置详细流程视频...
在玩家背景下!天天福建十三兵修... 在玩家背景下!天天福建十三兵修改器(辅助挂)果然确实有挂(有挂方针)-哔哩哔哩 【无需打开直接搜索加...
四分钟开挂!皮皮衡阳字牌黑科技... 四分钟开挂!皮皮衡阳字牌黑科技视频,吉祥填大坑攻略,教你攻略-2026最新版本1、打开软件启动之后找...
目前来看!hhpoker有没有... 目前来看!hhpoker有没有作比(辅助挂)果然确实有挂(有挂办法)-哔哩哔哩;无需打开直接搜索微信...
第7分钟开挂!微信边锋辅助软件... 第7分钟开挂!微信边锋辅助软件,小南娱乐科技,微扑克教程-2026最新版本1、任何微信边锋辅助软件a...
有消息称!吉祥填大坑有什么诀窍... 有消息称!吉祥填大坑有什么诀窍(辅助挂)果然真的是有挂(有挂操作)-哔哩哔哩>>您好:软件加薇136...
1分钟开挂!微乐河南小程序微乐... 1分钟开挂!微乐河南小程序微乐辅助脚本,微信边锋辅助,爆料教程-2026最新版本1、打开软件启动之后...
此事备受玩家关注!微信小程序财... 此事备受玩家关注!微信小程序财神十三章特殊牌(辅助挂)原来真的有挂(有挂指南)-哔哩哔哩,微信小程序...
第九分钟开挂!新玄龙辅助工具,... 第九分钟开挂!新玄龙辅助工具,乐乐围棋入门辅助,微扑克教程-2026最新版本1、上手简单,内置详细流...
据文件显示!益乐绍兴辅助(辅助... 据文件显示!益乐绍兴辅助(辅助挂)果然是有挂(有挂手段)-哔哩哔哩;无需打开直接搜索打开薇:1367...