gpt4 book ai didi

angular - 在 Angular 中的项目之间共享服务的最佳实践

转载 作者:行者123 更新时间:2023-12-05 06:27:32 26 4
gpt4 key购买 nike

我知道创建一个库是在项目之间共享公共(public)代码的推荐方式,但有人说你应该只在那里存储无状态和独立的服务。

我正在做的两个项目是同一个网站的两个方面。
一个面向客户,另一个面向我们,获取所有统计数据、管理工具等。

很多部分是不同的,但有些部分使用相同的实体。
例如,如果我需要获取商店列表,我将使用一些代码来构建请求并将其发送到后端。但是两个项目的代码是相同的。

由于代码依赖于当前的环境文件(因为不同的 API url),显然将它放在库中对我来说没有意义。

我还有其他选择吗?或者可以有重复的点点滴滴吗?

最佳答案

在库中(假设'my-lib')你必须实现提供服务的模块:

@NgModule({})
export class SomeServiceModule {
static forRoot(): ModuleWithProviders {
return {
ngModule: SomeServiceModule,
providers: [
{ provide: SomeService, useClass: SomeService }
]
};
}
}

您的应用将像这样使用它:

import { SomeServiceModule } from 'my-lib';

@NgModule({
imports: [ BrowserModule, FormsModule, SomeServiceModule.forRoot() ],
declarations: [ AppComponent ],
bootstrap: [ AppComponent ]
})
export class AppModule { }

参见 docs更多信息和stackblitz source code

关于angular - 在 Angular 中的项目之间共享服务的最佳实践,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55166931/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com