elementAt

function stable

Emits the single value at the specified index in a sequence of emissions from the source Observable.

elementAt<T, D = T>(index: number, defaultValue?: D): OperatorFunction<T, T | D>

Parameters

index

Is the number i for the i-th source emission that has happened since the subscription, starting from the number 0.

defaultValue

Optional. Default is undefined.

The default value returned for missing indices.

Returns

OperatorFunction<T, T | D>: A function that returns an Observable that emits a single item, if it is found. Otherwise, it will emit the default value if given. If not, it emits an error.

Throws

ArgumentOutOfRangeError When using elementAt(i), it delivers an ArgumentOutOfRangeError to the Observer's error callback if i < 0 or the Observable has completed before emitting the i-th next notification.

Description

Emits only the i-th value, then completes.

elementAt marble diagram

elementAt returns an Observable that emits the item at the specified index in the source Observable, or a default value if that index is out of range and the default argument is provided. If the default argument is not given and the index is out of range, the output Observable will emit an ArgumentOutOfRangeError error.

Example

Emit only the third click event

import { fromEvent } from 'rxjs';
import { elementAt } from 'rxjs/operators';

const clicks = fromEvent(document, 'click');
const result = clicks.pipe(elementAt(2));
result.subscribe(x => console.log(x));

// Results in:
// click 1 = nothing
// click 2 = nothing
// click 3 = MouseEvent object logged to console

See Also

© 2015–2021 Google, Inc., Netflix, Inc., Microsoft Corp. and contributors.
Code licensed under an Apache-2.0 License. Documentation licensed under CC BY 4.0.
https://rxjs.dev/api/operators/elementAt