web-dev-qa-db-de.com

angle2 rxjs beobachtbare Gabelung

Ist es möglich, http.get-Anfragen weiter zu bearbeiten, auch wenn eine der Anfragen fehlschlägt?.

Ich freue mich auf eine ähnliche Funktion von $ q.allSettled in angular2.

Siehe Beispiel: 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

Sie können den Operator catch für jede Observable verwenden, um den Fehler abzufangen und in solchen Fällen eine andere Observable zurückzugeben.

Hier ist ein Beispiel:

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

Verwendet Observable.forkJoin (), um mehrere gleichzeitige http.get () - Anforderungen auszuführen. Der gesamte Vorgang führt zu einem Fehlerstatus, wenn eine einzelne Anforderung fehlschlägt.

 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())
    );

Sie können jedoch Ihre zusätzliche GET-Anforderung in den Fehlerhandler stellen:

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