take<T>(count: number): MonoTypeOperatorFunction<T>
| count | El máximo número de valores que se emitirán. |
MonoTypeOperatorFunction<T>: Un Observable que emite o las primeras count emisiones del Observable fuente, o todas las emisiones si el Observable fuente emite menos de count valores.
ArgumentOutOfRangeError Cuando se usa take(i), se lanza un Error ArgumentOutOrRangeError si i < 0.
Obtiene los primeros count valores de la fuente, y se completa.
take retorna un Observable que emite únicamente los primeros count valores emitidos por el Observable fuente. Si la fuente emite menos de n valores, entonces se emiten todos los valores. Después, se completa el Observable, independientemente de si la fuente se completa o no.
Emitir las primeras 5 teclas pulsadas
import { map, take } from "rxjs/operators";
import { fromEvent } from "rxjs";
const key$ = fromEvent<KeyboardEvent>(document, "keydown");
key$
.pipe(
map(({ code }) => code),
take(5)
)
.subscribe(console.log);
// Salida: KeyR, KeyX, KeyJ, KeyS, Space
Emitir los primeros 3 títulos de películas de Studio Ghibli
import { ajax } from "rxjs/ajax";
import { map, mergeAll, take } from "rxjs/operators";
const ghibliFilm$ = ajax.getJSON("https://ghibliapi.herokuapp.com/films").pipe(
mergeAll(),
map(({ title }) => title)
);
ghibliFilm$.pipe(take(5)).subscribe(console.log);
// Salida: Castle in the Sky, Grave of the Fireflies, My Neighbor Totoro
Obtener los 5 primeros segundos de un Observable infinito de un intervalo de 1 segundo.
import { interval } from "rxjs";
import { take } from "rxjs/operators";
const intervalCount = interval(1000);
const takeFive = intervalCount.pipe(take(5));
takeFive.subscribe((x) => console.log(x));
// Salida: 0, 1, 2, 3, 4
Documentación oficial en inglés