Я следил за этим сообщением (http://www.adonespitogo.com/articles/angular-2-extending-http-provider/), чтобы расширить класс Http и добавил статический метод, который возвращает однотонный Http.
./services/http.service.ts
import { Injectable, ReflectiveInjector } from '@angular/core';
import {
BaseResponseOptions,
BaseRequestOptions,
BrowserXhr,
ConnectionBackend,
CookieXSRFStrategy,
Headers,
Http as HttpParent,
Request,
RequestOptions,
RequestOptionsArgs,
Response,
ResponseOptions,
XHRBackend,
XSRFStrategy
} from '@angular/http';
import { Observable } from 'rxjs/Observable';
@Injectable()
export class CustomHttp extends HttpParent {
public static getInstance() {
if (!(this._instance instanceof CustomHttp)) {
this._instance = ReflectiveInjector.resolveAndCreate([
CustomHttp, BrowserXhr, XHRBackend,
{ provide: ConnectionBackend, useClass: XHRBackend },
{ provide: ResponseOptions, useClass: BaseResponseOptions },
{ provide: XSRFStrategy, useFactory:() => {
return new CookieXSRFStrategy();
}
},
{ provide: RequestOptions, useClass: BaseRequestOptions }
]).get(CustomHttp);
}
return this._instance;
}
private static _instance: CustomHttp;
}
./app.module.ts
import { NgModule } from '@angular/core';
import { HttpModule, RequestOptions, XHRBackend } from '@angular/http';
import { CustomHttp } from './services/http.service';
@NgModule({
bootstrap: [
AppComponent
],
declarations: [
AppComponent
],
imports: [
HttpModule
],
providers: [
{
provide: CustomHttp,
useFactory: (backend: XHRBackend, options: RequestOptions) => {
return new CustomHttp(backend, options);
},
deps: [XHRBackend, RequestOptions]
};
]
})
export class AppModule {}
./services/validation.service.ts
import CustomHttp from './http.service';
export class ValidationService {
static public doSomething() {
CustomHttp.getInstance().get('some/api/').subscribe(
(response) => {
console.log(response);
})
}
}
Надеюсь, это сработает для вас.
Спасибо, тогда я думаю, Я должен изменить статичность. Думаю, мне нужно больше об этом поговорить. – revathi
Можете ли вы подробно остановиться на решении? Я испытываю аналогичную проблему с службой проверки и следую этому руководству [link] (https://coryrylan.com/blog/angular-form-builder-and-validation-management), чтобы создать проверки для формы. При вводе http-сервиса я получаю undefined. Я немного незнакомый со статическими функциями и не уверен, что именно по этой причине он не работает? – PBandJen
Как работает служба проверки, связанная со статическим методом? Возможно, было бы лучше создать новый вопрос, в котором вы добавите код, демонстрирующий то, что вы пытаетесь выполнить. –