Skip to content

Latest commit

 

History

History
79 lines (65 loc) · 2.76 KB

distinct.md

File metadata and controls

79 lines (65 loc) · 2.76 KB

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

  1. [keySelector] (Function): A function to compute the comparison key for each element.
  2. [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.from([
        42, 24, 42, 24
    ])
    .distinct();

var subscription = source.subscribe(
    function (x) {
        console.log('Next: ' + x.toString());
    },
    function (err) {
        console.log('Error: ' + err);
    },
    function () {
        console.log('Completed');
    });

// => Next: 42
// => Next: 24
// => Completed

/* With key selector */
var source = Rx.Observable.from([
        {value: 42}, {value: 24}, {value: 42}, {value: 24}
    ])
    .distinct(function (x) { return x.value; });

var subscription = source.subscribe(
    function (x) {
        console.log('Next: ' + x.toString());
    },
    function (err) {
        console.log('Error: ' + err);
    },
    function () {
        console.log('Completed');
    });

// => Next: { value: 42 }
// => Next: { value: 24 }
// => Completed

Location

File:

Dist:

NPM Packages:

NuGet Packages:

Unit Tests: