Это очень хороший вопрос, у нас тоже есть разные серверы (Dev, QC, Stage, Prod), поэтому создание отдельной сборки для каждой среды занимает очень много времени, я никогда не пробовал такой подход к созданию отдельного файла средыДля каждой среды мы решили эту проблему, сохранив URL-адреса и константы Api в файле json.
, поэтому сначала создайте файл json и поместите его в папку assets .
Config.json
{
"url":{
"apiUrl": "http://localhost:58357/"
}
}
Создайте класс модели, который должен иметь свойства с таким же именем, как у Config.json file
Config.ts
export class Config {
url: {
apiUrl: string;
};
}
Создание службы для импорта Config.json файл
app.config.service.ts
import { Injectable } from '@angular/core';
import { Config } from './models/config';
import { HttpClient, HttpBackend, HttpResponse } from '@angular/common/http';
import { Observable } from '../node_modules/rxjs';
import { map } from 'rxjs/operators';
@Injectable({
providedIn: 'root'
})
export class AppConfig {
static Settings: Config;
private http: HttpClient;
constructor(private httpBackEnd: HttpBackend) {
this.http = new HttpClient(httpBackEnd);
}
load() {
const jsonFile = 'assets/config.json';
return new Promise<void>((resolve, reject) => {
this.http.get(jsonFile).toPromise().then((response: Config) => {
AppConfig.Settings = <Config>response;
resolve();
}).catch((response: any) => {
reject(`Could not load file '${jsonFile}': ${JSON.stringify(response)}`);
});
});
}
}
app.module.ts
import { BrowserModule } from '@angular/platform-browser';
import { NgModule, APP_INITIALIZER } from '@angular/core';
import { AppComponent } from './app.component';
import { AppConfig } from '../app.config.service';
import { HttpClientModule } from '../../node_modules/@angular/common/http';
export function initConfig(appConfig: AppConfig) {
return () => appConfig.load();
}
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
HttpClientModule,
],
providers: [
AppConfig, { provide: APP_INITIALIZER, useFactory: initConfig, deps: [AppConfig], multi: true },
],
bootstrap: [AppComponent]
})
export class AppModule { }
импортировать AppConfig в любой файл компонента, где вы хотите использовать ключи, хранящиеся в файле json.
app.component.ts
import { Component } from '@angular/core';
import { AppConfig } from '../app.config.service';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
title = 'ConstantsManagerDemo';
constructor() {
const apiUrl = AppConfig.Settings.url.apiUrl;
alert(apiUrl);
}
}
перейти к tsconfig.json файл и добавить
"allowSyntheticDefaultImports" :true,
under compilerOptions