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 with the following arguments:acc
:Any
- the accumulated value.currentValue
:Any
- the current valueindex
:Number
- the current indexsource
:Observable
- the current observable instance
[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, i, source) { 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, i, source) { 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: