scan
函数签名: scan(accumulator: function, seed: any): Observable
随着时间的推移进行归并。
此操作符是许多基于 Redux 实现的 RxJS 的核心!
示例
示例 1: 随着时间的推移计算总数
( StackBlitz )
// RxJS v6+
import { of } from 'rxjs';
import { scan } from 'rxjs/operators';
const source = of(1, 2, 3);
// 基础的 scan 示例,从0开始,随着时间的推移计算总数
const example = source.pipe(scan((acc, curr) => acc + curr, 0));
// 输出累加值
// 输出: 1,3,6
const subscribe = example.subscribe(val => console.log(val));
示例 2: 对对象进行累加
( StackBlitz | jsBin | jsFiddle )
// RxJS v6+
import { Subject } from 'rxjs';
import { scan } from 'rxjs/operators';
const subject = new Subject();
// scan 示例,随着时间的推移构建对象
const example = subject.pipe(
scan((acc, curr) => Object.assign({}, acc, curr), {})
);
// 输出累加值
const subscribe = example.subscribe(val =>
console.log('Accumulated object:', val)
);
// subject 发出的值会被添加成对象的属性
// {name: 'Joe'}
subject.next({ name: 'Joe' });
// {name: 'Joe', age: 30}
subject.next({ age: 30 });
// {name: 'Joe', age: 30, favoriteLanguage: 'JavaScript'}
subject.next({ favoriteLanguage: 'JavaScript' });
示例 3: 随机发出累加数组中的值。
( StackBlitz )
// RxJS v6+
import { interval } from 'rxjs';
import { scan, map, distinctUntilChanged } from 'rxjs/operators';
// 累加数组中的值,并随机发出此数组中的值
const scanObs = interval(1000)
.pipe(
scan((a, c) => [...a, c], []),
map(r => r[Math.floor(Math.random() * r.length)]),
distinctUntilChanged()
)
.subscribe(console.log);
相关食谱
其他资源
- scan - 官方文档
- 使用 RxJS 中的 reduce 和 scan 聚集流 - Ben Lesh
- 使用 scan 更新数据 - John Linquist
- 转换操作符: scan - André Staltz
源码: https://github.com/ReactiveX/rxjs/blob/master/src/internal/operators/scan.ts