RxJS reduce

2020-10-14 10:29 更新

在源 Observable 上應(yīng)用累加器函數(shù),并在給定可選種子值的情況下在源完成時(shí)返回累加結(jié)果。

reduce<T, R>(accumulator: (acc: T | R, value: T, index?: number) => T | R, seed?: T | R):OperatorFunction<T, T | R>

參量

累加器 在每個(gè)源值上調(diào)用累加器函數(shù)。
種子 可選的。默認(rèn)值為undefined。初始累積值。

returns

OperatorFunction<T, T | R>:一個(gè) Observable 發(fā)出一個(gè)值,該值是對(duì)源 Observable 發(fā)出的值進(jìn)行累加的結(jié)果。

描述

使用累加器函數(shù)將源上發(fā)出的所有值合并在一起,該函數(shù)知道如何將新的源值結(jié)合到過(guò)去的累加中。

減少大理石圖

像 Array.prototype.reduce()一樣 , 對(duì)累積和源 Observable 的每個(gè)值(過(guò)去)reduce應(yīng)用一個(gè)accumulator函數(shù),以將其減少為單個(gè)值,并在輸出 Observable 上發(fā)出該值。請(qǐng)注意reduce,僅當(dāng)源 Observable 完成時(shí)才會(huì)發(fā)出一個(gè)值。等效于應(yīng)用運(yùn)算符,scan然后是 operator last

返回一個(gè) Observable,它將一個(gè)指定的accumulator函數(shù)應(yīng)用于源 Observable 發(fā)出的每個(gè)項(xiàng)目。如果 seed 指定了一個(gè)值,則該值將用作累加器的初始值。如果未指定種子值,則將源的第一項(xiàng)用作seed。

計(jì)算 5 秒鐘內(nèi)發(fā)生的點(diǎn)擊事件數(shù)

import { fromEvent, interval } from 'rxjs';
import { reduce, takeUntil, mapTo } from 'rxjs/operators';


const clicksInFiveSeconds = fromEvent(document, 'click').pipe(
  takeUntil(interval(5000)),
);
const ones = clicksInFiveSeconds.pipe(mapTo(1));
const seed = 0;
const count = ones.pipe(reduce((acc, one) => acc + one, seed));
count.subscribe(x => console.log(x));

超載

reduce(accumulator: (acc: R, value: T, index: number) => R, seed: R): OperatorFunction<T, R>

參量 類(lèi)型
累加器 類(lèi)型:(acc: R, value: T, index: number) => R
seed 類(lèi)型:R

returnsOperatorFunction<T, R>
reduce(accumulator: (acc: T, value: T, index: number) => T, seed?: T): MonoTypeOperatorFunction<T>

參量 類(lèi)型
累加器 類(lèi)型:(acc: T, value: T, index: number) => T
seed 可選的。默認(rèn)值為undefined。類(lèi)型:T

returnsMonoTypeOperatorFunction<T> reduce(accumulator: (acc: R, value: T, index: number) => R): OperatorFunction<T, R>

參量 類(lèi)型
累加器 類(lèi)型:(acc: R, value: T, index: number) => R

returnsOperatorFunction<T, R>

也可以看看

以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)