Applies an accumulator function over an observable sequence and returns each intermediate result. The optional seed value is used as the initial accumulator value.
For aggregation behavior with no intermediate results, see Rx.Observable#reduce
.
Note the Rx.Observable.prototype.scan([seed], accumulator)
has been removed as per v3.0 and replaced with Rx.Observable.prototype.scan(accumulator, [seed])
.
accumulator
(Function
): An accumulator function to be invoked on each element.[seed]
(Any
): The initial accumulator value.
(Observable
): An observable sequence which results from the comonadic bind operation.
/* Without a seed */
var source = Rx.Observable.range(1, 3)
.scan(function (acc, x) { return acc + x; });
var subscription = source.subscribe(
function (x) {
console.log('Next: %s', x);
},
function (err) {
console.log('Error: %s', err);
},
function () {
console.log('Completed');
});
// => Next: 1
// => Next: 3
// => Next: 6
// => Completed
/* With a seed */
var source = Rx.Observable.range(1, 3)
.scan(function (acc, x) { return acc * x; }, 1);
var subscription = source.subscribe(
function (x) {
console.log('Next: %s', x);
},
function (err) {
console.log('Error: %s', err);
},
function () {
console.log('Completed');
});
// => Next: 1
// => Next: 2
// => Next: 6
// => Completed
File:
Dist:
Prerequisites:
- None
NPM Packages:
NuGet Packages:
Unit Tests: