Comment annuler une requête HTTP dans Angular 2?
Je sais comment rejeter la promesse de demande uniquement.
return new Promise((resolve, reject) => {
this.currentLoading.set(url, {resolve, reject});
this.http.get(url, {headers: reqHeaders})
.subscribe(
(res) => {
res = res.json();
this.currentLoading.delete(url);
this.cache.set(url, res);
resolve(res);
}
);
});
Vous pouvez appeler unsubscribe
let sub = this.http.get(url, {headers: reqHeaders})
.subscribe(
(res) => {
res = res.json();
this.currentLoading.delete(url);
this.cache.set(url, res);
resolve(res);
}
);
sub.unsubscribe();
Plus d'infos ici: http://www.syntaxsuccess.com/viewarticle/angular-2.0-and-http
Vous pouvez utiliser la solution simple suivante.
if ( this.subscription ) {
this.subscription.unsubscribe();
}
this.subscription = this.http.get( 'awesomeApi' )
.subscribe((res)=> {
// your awesome code..
})
Un peu tard pour la fête, mais voici mon point de vue:
import { Injectable } from '@angular/core'
import { Http } from '@angular/http'
import { Observable } from 'rxjs/Observable'
import { Subscriber } from 'rxjs/Subscriber'
@Injectable ()
export class SomeHttpServiceService {
private subscriber: Subscriber<any>
constructor(private http: Http){ }
public cancelableRequest() {
let o = new Observable(obs => subscriber = obs)
return this.http.get('someurl').takeUntil(o)
.toPromise() //I dont like observables
.then(res => {
o.unsubscribe
return res
})
}
public cancelRequest() {
subscriber.error('whatever')
}
}
Cela vous permet d'annuler manuellement une demande. Je finis parfois avec une observable ou une promesse qui modifiera un résultat sur la page. Si la requête a été lancée automatiquement (l'utilisateur n'a pas tapé aucune valeur dans un champ pendant x millis), la requête est abandonnée (Nice est en train de taper quelque chose à nouveau) ...
takeUntil devrait également fonctionner avec un délai d’attente simple (Observable.timer) si c’est ce que vous recherchez https://www.learnrxjs.io/operators/filtering/takeuntil.html
Vous pouvez utiliser SwitchMap sur l'observable, ce qui annulera les réponses des requêtes précédentes et demandera uniquement la dernière:
https://www.learnrxjs.io/operators/transformation/switchmap.html
Utilisez switchMap
[docs] , qui annulera toutes les demandes en vol et utilisera uniquement les dernières.
get(endpoint: string): Observable<any> {
const headers: Observable<{url: string, headers: HttpHeaders}> = this.getConfig();
return headers.pipe(
switchMap(obj => this.http.get(`${obj.url}${endpoint}`, { headers: obj.headers, params: params }) ),
shareReplay(1)
);
}
shareReplay émettra la dernière valeur pour tous les abonnés en retard.