如何从延迟加载的模块访问 AppModule 模块导入?

cuz*_*ter 7 javascript module lazy-loading angular

如何从延迟加载的模块访问 AppModule 导入?

我的Angular10应用程序将AngularMaterial 和 NXTranslate 模块导入到 AppModule 中。NxTranslate 调用 ApiService 来获取包含数千个翻译的大型 Lookup 对象。这是在 AppModule 的初始加载时转换的。

该应用程序有多个延迟加载的路由,它们也需要在其功能中使用 AnagularMaterial 和 NXTranslate 模块。

如果我使用SharedModule 加载模块,则多次调用 ApiService。这显然不好。它应该只调用一次 ApiService 和 AngularMaterial 并且可用于所有模块。

我该如何解决?我在挣扎。谢谢。


更新 (对不起,这篇文章太长了)这是NXTranslate实现 - 它使用自定义类。

import { environment } from './../../../../environments/environment';
import { OSCITranslateService } from './translate.service';
import { NgModule, Injector } from '@angular/core';
import { CommonModule } from '@angular/common';
import {TranslateLoader, TranslateModule} from '@ngx-translate/core';
import {TranslateHttpLoader} from '@ngx-translate/http-loader';
import {HttpClient, HttpClientModule} from '@angular/common/http';
import { Observable, of } from 'rxjs';
import { map } from 'rxjs/operators';

export class CustomLoader implements TranslateLoader {

localeResourcesUrl =
`${environment.baseUrl}${environment.apiUrl.localeResources}`;

constructor(private http: HttpClient) {}

getTranslation(lang: string): Observable<any> {
let  options;
const uri = `${this.localeResourcesUrl}${options && options.key ? 
'/' + options.key : ''}`;

let mapped = this.http.get(uri).pipe(
  map((response: any) => {
    let localeData = {};
    let languageCode = response?.languageVariantCode;

    response.resources.forEach(item => {
      localeData[item.keyName] = item.keyValue;
    });
    return localeData;
  })
);
return mapped;
}
}

@NgModule({
declarations: [],
imports: [
CommonModule,
HttpClientModule,
TranslateModule.forRoot({
    loader: {
        provide: TranslateLoader,
        useClass: CustomLoader,
        deps: [HttpClient]
    }
})
],
exports: [ TranslateModule ]
})
export class NxTranslateModule { 

constructor(private http: HttpClient) {
}
}
Run Code Online (Sandbox Code Playgroud)

这是sharedRootModule是进口AngularMaterial&NXTranslate

import { SharedModule } from './shared.module';
import { NgModule, ModuleWithProviders } from '@angular/core';

@NgModule({
})
export class SharedRootModule {

  static forRoot(): ModuleWithProviders<SharedModule> {
    return {
      ngModule: SharedModule
    };
  }
}
Run Code Online (Sandbox Code Playgroud)

上文AppModule SharedRootModule进口

...
@NgModule({
  declarations: [
     AppComponent
  ],
  imports: [
    ...
    SharedRootModule.forRoot()
  ],
  exports: [
    ...
    SharedRootModule
  ]
....
Run Code Online (Sandbox Code Playgroud)

小智 0

您是否担心最终可能会得到多个 ApiService 实例?仅在 AppModule 中提供 ApiService,或者更好的是,使用providedIn服务装饰器中的属性,以便它在应用程序级别注入。(https://angular.io/api/core/Injectable#providedIn

我只想使用一个 SharedModule 来导出提到的延迟加载模块。