我正在使用webpack开发一个基于Angular2的Web应用程序,我们当前的计划是打开某种文件来配置我们应用程序的功能(可能是.json)。这主要是为了提供一个易于定位的文件给实施我们应用程序的人指定一些东西,例如:他们的API在哪里,如果他们想添加自定义样式表等。
我使用的加载配置文件的服务如下:
//config.ts
@Injectable()
export class Config {
private static _config: Object;
private static _promise: Promise<any>;
constructor(private http: Http) {
Config._promise = this.load();
}
load() {
return new Promise((resolve, reject) => {
this.http.get(`./config/development.json`)
.map((response: Response) => response.json())
.catch((error: any) => {
console.error(error);
return Observable.throw(error.json().error || 'Server error');
})
.subscribe((data) => {
Config._config = data;
resolve(true);
});
});
}
get(key: any) {
return Config._config[key];
}
}
我正在另一个服务类中使用它:
//api.service.ts
@Injectable()
export class ApiService {
private URI: string;
constructor(private http: Http, private _config: Config) {
this.URI = this._config.get('apiUrl');
}
getCustomQueries(): Observable<any> {
return this.http
.get(`${this.URI}/CustomQuery`)
.map((response: Response) => {
let data = response.json();
return { QueryID: data.id, QueryName: data.name };
})
.catch(this.handleError);
}
}
我想知道有没有办法在以下任意一种情况下加载config.ts:
- 在应用程序根组件引导之前
- 在ApiService实例化之前
- 在调用ApiService的服务方法之前
或者
- 其他完全不同的为Angular2应用程序添加可配置性的方式。