On this page
reduce
function
stable
operator
Applies an accumulator function over the source Observable, and returns the accumulated result when the source completes, given an optional seed value.
reduce<V, A>(accumulator: (acc: V | A, value: V, index: number) => A, seed?: any): OperatorFunction<V, V | A>
Parameters
accumulator |
(acc: V | A, value: V, index: number) => A |
The accumulator function called on each source value. |
seed |
any |
Optional. Default is The initial accumulation value. |
Returns
OperatorFunction<V, V | A>
: A function that returns an Observable that emits a single value that is the result of accumulating the values emitted by the source Observable.
Description
Combines together all values emitted on the source, using an accumulator function that knows how to join a new source value into the accumulation from the past.
Like Array.prototype.reduce(), reduce
applies an accumulator
function against an accumulation and each value of the source Observable (from the past) to reduce it to a single value, emitted on the output Observable. Note that reduce
will only emit one value, only when the source Observable completes. It is equivalent to applying operator scan
followed by operator last
.
Returns an Observable that applies a specified accumulator
function to each item emitted by the source Observable. If a seed
value is specified, then that value will be used as the initial value for the accumulator. If no seed value is specified, the first item of the source is used as the seed.
Example
Count the number of click events that happened in 5 seconds
import { fromEvent, takeUntil, interval, map, reduce } from 'rxjs';
const clicksInFiveSeconds = fromEvent(document, 'click')
.pipe(takeUntil(interval(5000)));
const ones = clicksInFiveSeconds.pipe(map(() => 1));
const seed = 0;
const count = ones.pipe(reduce((acc, one) => acc + one, seed));
count.subscribe(x => console.log(x));
Overloads
reduce(accumulator: (acc: V | A, value: V, index: number) => A): OperatorFunction<V, V | A>
Parameters
accumulator |
(acc: V | A, value: V, index: number) => A |
Returns
OperatorFunction<V, V | A>
reduce(accumulator: (acc: A, value: V, index: number) => A, seed: A): OperatorFunction<V, A>
Parameters
accumulator |
(acc: A, value: V, index: number) => A |
|
seed |
A |
Returns
OperatorFunction<V, A>
reduce(accumulator: (acc: A | S, value: V, index: number) => A, seed: S): OperatorFunction<V, A>
Parameters
accumulator |
(acc: A | S, value: V, index: number) => A |
|
seed |
S |
Returns
OperatorFunction<V, A>
See Also
© 2015–2022 Google, Inc., Netflix, Inc., Microsoft Corp. and contributors.
Code licensed under an Apache-2.0 License. Documentation licensed under CC BY 4.0.
https://rxjs.dev/api/index/function/reduce