Rx.Observable.prototype.distinct([keySelector], [comparer])
Returns an observable sequence that contains only distinct elements according to the keySelector and the comparer. Usage of this operator should be considered carefully due to the maintenance of an internal lookup structure which can grow large.
Arguments
[keySelector]
(Function
): A function to compute the comparison key for each element.[comparer]
(Function
): Used to compare objects for equality. If not provided, defaults to an equality comparer function.
Returns
(Observable
): An observable sequence only containing the distinct elements, based on a computed key value, from the source sequence.
Example
/* Without key selector */
var source = Rx.Observable.of(42, 24, 42, 24)
.distinct();
var subscription = source.subscribe(
function (x) {
console.log('Next: %s', x);
},
function (err) {
console.log('Error: %s', err);
},
function () {
console.log('Completed');
});
// => Next: 42
// => Next: 24
// => Completed
/* With key selector */
var source = Rx.Observable.of({value: 42}, {value: 24}, {value: 42}, {value: 24})
.distinct(function (x) { return x.value; });
var subscription = source.subscribe(
function (x) {
console.log('Next: %s', x);
},
function (err) {
console.log('Error: %s', err);
},
function () {
console.log('Completed');
});
// => Next: { value: 42 }
// => Next: { value: 24 }
// => Completed
Location
File:
Dist:
NPM Packages:
NuGet Packages:
Unit Tests: