Returns the only element of an observable sequence that satisfies the condition in the optional predicate, and reports an exception if there is not exactly one element in the observable sequence.
[predicate]
(Function
): A predicate function to evaluate for elements in the source sequence. The callback is called with the following information:- the value of the element
- the index of the element
- the Observable object being subscribed
[thisArg]
(Any
): Object to use asthis
when executing the predicate.
(Observable
): Sequence containing the single element in the observable sequence that satisfies the condition in the predicate.
/* No Match */
var source = Rx.Observable.empty()
.single();
var subscription = source.subscribe(
function (x) {
console.log('Next: ' + x);
},
function (err) {
console.log('Error: ' + err);
},
function () {
console.log('Completed');
});
// => Error: Error: Sequence contains no elements.
/* Without a predicate */
var source = Rx.Observable.return(42)
.single();
var subscription = source.subscribe(
function (x) {
console.log('Next: ' + x);
},
function (err) {
console.log('Error: ' + err);
},
function () {
console.log('Completed');
});
// => Next: 42
// => Completed
/* With a predicate */
var source = Rx.Observable.range(0, 10)
.single(function (x, idx, obs) { return x === 1; });
var subscription = source.subscribe(
function (x) {
console.log('Next: ' + x);
},
function (err) {
console.log('Error: ' + err);
},
function () {
console.log('Completed');
});
// => Next: 1
// => Completed
/* More than one match */
var source = Rx.Observable.range(0, 10)
.single(function (x, idx, obs) { return x % 2 === 0; });
var subscription = source.subscribe(
function (x) {
console.log('Next: ' + x);
},
function (err) {
console.log('Error: ' + err);
},
function () {
console.log('Completed');
});
// => Error: Error: Sequence contains more than one element'
File:
Dist:
Prerequisites:
NPM Packages:
NuGet Packages:
Unit Tests: