Angular导入的模块不等待APP_INITIALIZER
创始人
2024-10-24 00:00:44
0

一种解决方法是在应用程序主模块中使用APP_INITIALIZER,并将其注册为providers。在接下来的示例中,我们使用一个名为ConfigService的服务来模拟导入依赖项的过程,以及一个名为appInitProvider的提供者,以便等待这些依赖项导入完毕后再继续应用程序的启动。

app.module.ts:

import { APP_INITIALIZER, NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { HttpClientModule } from '@angular/common/http';
import { ConfigService } from './shared/config.service';
import { AppComponent } from './app.component';

function appInit(configService: ConfigService) {
  return () => configService.loadConfig();
}

@NgModule({
  declarations: [AppComponent],
  imports: [BrowserModule, HttpClientModule],
  providers: [
    ConfigService,
    {
      provide: APP_INITIALIZER,
      useFactory: appInit,
      deps: [ConfigService],
      multi: true,
    },
  ],
  bootstrap: [AppComponent],
})
export class AppModule {}

在上面的示例中,我们注入了ConfigService,并将其传递给appInit函数。该函数将其返回值设置为一个可以解析的Promise对象来表示应用程序完成启动所需的依赖项已完成加载。最后,我们将appInitProvider提供者注册为APP_INITIALIZER的依赖项。

ConfigService示例:

import { HttpClient } from '@angular/common/http';
import { Injectable } from '@angular/core';

@Injectable({
  providedIn: 'root',
})
export class ConfigService {
  private configUrl = 'assets/config.json';

  constructor(private http: HttpClient) {}

  loadConfig() {
    return this.http.get(this.configUrl).toPromise();
  }
}

上面的示例具有简单的loadConfig方法,以便在应用程序启动时导入config.json文件。当loadConfig方法完成时,它将返回Promise对象。

这是一种可靠的方法,让你的应用程序在应用程序依赖项完成导入后继续启动。

相关内容

热门资讯

四分钟发现!点点长牌辅助工具教... 四分钟发现!点点长牌辅助工具教程(辅助挂)原来确实有挂(攻略方法开挂辅助脚本);无需打开直接搜索打开...
第1分钟明白!靖边打锅子奇迹陕... 【亲,靖边打锅子奇迹陕西辅助下载 这款游戏可以开挂的,确实是有挂的,很多玩家在这款靖边打锅子奇迹陕西...
第六分钟了解!中至江西源代码(... 第六分钟了解!中至江西源代码(辅助挂)一直真的是有挂(AI教程开挂辅助脚本);无需打开直接搜索薇:1...
1分钟开挂!潮汕汇软件辅助(辅... 1分钟开挂!潮汕汇软件辅助(辅助挂)果然确实有挂(2026教程开挂辅助插件);无需打开直接搜索加薇1...
第六分钟明白!人海大厅挂件怎么... 第六分钟明白!人海大厅挂件怎么买(辅助挂)其实真的是有挂(2026新版教程开挂辅助平台)您好:人海大...
第2分钟开挂!牛总管辅助免费版... 第2分钟开挂!牛总管辅助免费版(辅助挂)其实是有挂的(新版2026教程开挂辅助神器)《详细加薇136...
5分钟科普!九九山城万州版脚本... 5分钟科普!九九山城万州版脚本(辅助挂)原来真的有挂(扑克教程!开挂辅助神器) >>您好:软件加薇1...
第3分钟讲究!友间十三道有什么... 第3分钟讲究!友间十三道有什么窍门(辅助挂)原来确实有挂(玩家教程开挂辅助软件)《详细加薇13670...
四分钟辅助!阿当比鸡破解版2.... 四分钟辅助!阿当比鸡破解版2.0.0(辅助挂)果然确实有挂(教你教程开挂辅助平台)1、下载安装好阿当...
第三分钟开挂!西兵辅助器(辅助... 第三分钟开挂!西兵辅助器(辅助挂)原来是有挂的(玩家教程开挂辅助脚本) 了解更多开挂安装加(1367...