mergeAll
signature: mergeAll(concurrent: number): Observable
mergeAll(concurrent: number): ObservableCollect and subscribe to all observables.
💡 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
mergeAll 📰 - Official docs
mergeAll - In Depth Dev Reference
Flatten a higher order observable with mergeAll in RxJS 🎥 💵 - André Staltz
📁 Source Code: https://github.com/ReactiveX/rxjs/blob/master/src/internal/operators/mergeAll.ts
Last updated