web-dev-qa-db-fra.com

Comment annuler une requête HTTP dans Angular 2?

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);
            }
        );
});
50
tom10271

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

54
TGH

Vous pouvez utiliser la solution simple suivante.

if ( this.subscription ) {
   this.subscription.unsubscribe();
}
this.subscription = this.http.get( 'awesomeApi' )
 .subscribe((res)=> {
  // your awesome code..
})
48
Ervin Llojku

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

6
clearfix

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

6
Ben Taliadoros

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.

0
Ian