rxjs / latest / api / index / function / reduce.html

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 undefined.

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.

reduce marble diagram

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