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之间的循环依赖正确工作。

相关内容

热门资讯

黑科技软件!智星德州菠萝辅助器... 1、黑科技软件!智星德州菠萝辅助器免费下载,wpk辅助挂,必赢方法(有挂详情)-哔哩哔哩;代表性(透...
黑科技私人局!来玩德州app苹... 1、黑科技私人局!来玩德州app苹果下载(辅助挂)都是存在有挂(有挂辅助挂)-哔哩哔哩。2、来玩德州...
黑科技脚本!aapoker辅助... 黑科技脚本!aapoker辅助工具存在吗,we辅助poker德之星,安装教程(有挂教程)-哔哩哔哩1...
黑科技实锤!传奇扑克辅助(ai... 黑科技实锤!传奇扑克辅助(ai代打)素来存在有挂(有挂口控制)-哔哩哔哩;最新版2024是一款经典耐...
黑科技私人局!wpk用什么辅助... 黑科技私人局!wpk用什么辅助器(黑科技)都是真的有挂(有挂苹果版本)-哔哩哔哩;大神普及一款德州a...
黑科技ai!aapoker辅助... 黑科技ai!aapoker辅助工具存在吗,wepoke透明黑科技,力荐教程(有挂总结)-哔哩哔哩1、...
黑科技神器!wepoke的确有... 黑科技神器!wepoke的确有挂,德扑之星软件,技巧教程(有挂辅助挂)-哔哩哔哩;致您一封信;亲爱w...
黑科技脚本!微扑克线上代打工具... 1、黑科技脚本!微扑克线上代打工具(ai辅助)果然是有挂(有挂实锤)-哔哩哔哩;详细教程。2、微扑克...
黑科技机器人!wepokeai... 您好,wpk透视辅助合作这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家...
黑科技玄学!哈糖大菠萝有外挂吗... 黑科技玄学!哈糖大菠萝有外挂吗(黑科技)往昔是有挂(有挂下载)-哔哩哔哩;玩家必备必赢加哟《1367...