web-dev-qa-db-fra.com

angular2 rxjs observable forkjoin

Est-il possible de continuer les requêtes http.get forkjoin même si l'une des requêtes échoue.

Je regarde une fonction similaire de $ q.allSettled dans angular2.

Voir l'exemple: http://jsfiddle.net/Zenuka/pHEf9/

angular.module('qAllSettled', []).config(function($provide) {
  $provide.decorator('$q', function($delegate) {
    var $q = $delegate;
    $q.allSettled = function(promises) {
      return $q.all(promises.map(function(promise) {
        return promise.then(function(value) {
          return { state: 'fulfilled', value: value };
        }, function(reason) {
          return { state: 'rejected', reason: reason };
        });
      }));
    };
    return $q;
  });
});

Kab

17
kabus

Vous pouvez utiliser l'opérateur catch pour chaque observable pour intercepter l'erreur et renvoyer un autre observable dans de tels cas.

Voici un exemple:

return Observable.forkJoin(
  this.http.get('/some-url')
         .map((res:Response) => res.json())
         .catch(res:Response => Observable.of({}),
  this.http.get('/some-other-url')
         .map((res:Response) => res.json())
         .catch(res:Response => Observable.of({}),
);
31
Thierry Templier

Utilise Observable.forkJoin () pour exécuter plusieurs requêtes http.get () simultanées. Toute l'opération entraînera un état d'erreur si une seule demande échoue.

 getBooksAndMovies() {
    return Observable.forkJoin(
      this.http.get('/app/books.json').map((res:Response) => res.json()),
      this.http.get('/app/movies.json').map((res:Response) => res.json())
    );

Mais vous pouvez mettre votre demande GET supplémentaire dans le gestionnaire d'erreurs:

getBooksAndMovies() {
    Observable.forkJoin(
        this.http.get('/app/books.json').map((res:Response) => res.json()),
        this.http.get('/app/movies.json').map((res:Response) => res.json())
    ).subscribe(
      data => {
        this.books = data[0]
        this.movies = data[1]
      },
      err => console.error(err)
    );
3
AngJobs on Github