In my Angular2-typescript app, I'm using forkJoin to return an Observable only once all the parallel HTTP calls were made.
Issue: the subscription callback keeps being executed indefinitely
Here is my code:
http.service
import {Http} from "@angular/http";
constructor (private _http: HTTP) {}
makeGetRequest(....) {
return this._http.get(URL)
.map (res => res.json)
.toPromise();
my.service
import {Observable} from "rxjs/Observable";
import {HttpService} from "http.service"
constructor (private _httpService: HttpService) {}
myMethod(): Observable<any[]> {
return Observable.forkJoin(
this._httpService.makeGetRequest(
URL1
),
this._httpService.makeGetRequest(
URL2
)
)
}
my.component
import MyService from "my.service";
import Subscription from "rxjs";
constructor (private _service: MyService) {}
mySub: Subscription;
ngOnInit() {
this.mySub = this._service.myMethod.subscribe(data => {
data.forEach(console.log(data));
this.mySub.unsubscribe();
}
}
What I tried (same issue):
As forkJoin
reference says, it
Runs all observable sequences in parallel and collect their last elements.
This means that the operator gets values from completed observables and returns a completed observable with single value. There's no need to unsubscribe from it.