mergeAll
signature: mergeAll(concurrent: number): Observable
mergeAll(concurrent: number): ObservableCollect and subscribe to all observables.
:bulb: In many cases you can use mergeMap as a single operator instead!
Examples
( example tests )
Example 1: mergeAll with promises
( StackBlitz | jsBin | jsFiddle )
// RxJS v6+
import { map, mergeAll } from 'rxjs/operators';
import { of } from 'rxjs';
const myPromise = val =>
new Promise(resolve => setTimeout(() => resolve(`Result: ${val}`), 2000));
//emit 1,2,3
const source = of(1, 2, 3);
const example = source.pipe(
//map each value to promise
map(val => myPromise(val)),
//emit result from source
mergeAll()
);
/*
output:
"Result: 1"
"Result: 2"
"Result: 3"
*/
const subscribe = example.subscribe(val => console.log(val));Example 2: mergeAll with concurrent parameter
( StackBlitz | jsFiddle )
Additional Resources
:newspaper: - Official docs
Flatten a higher order observable with mergeAll in RxJS
:video_camera: :dollar: - André Staltz
:file_folder: Source Code: https://github.com/ReactiveX/rxjs/blob/master/src/internal/operators/mergeAll.ts
Last updated
Was this helpful?