zip<O extends ObservableInput<any>, R>(...observables: (O | ((...values: ObservedValueOf<O>[]) => R))[]): Observable<ObservedValueOf<O>[] | R>
observables | Tipo: (O | ((...values: ObservedValueOf[]) => R))[] . |
Observable<ObservedValueOf<O>[] | R>
Si el último parámetro es una función, esta se utiliza para computar el valor creado a partir de los valores de entrada. Si no, se retorna un array de los valores de entrada.
Esperar a que dos Observables emitan un valor, y emitir ambos valores en un array
import { zip, timer } from "rxjs";
import { mapTo } from "rxjs/operators";
const hello$ = timer(2000).pipe(mapTo("Hello"));
const world$ = timer(4000).pipe(mapTo("World"));
zip(hello$, world$).subscribe(console.log);
// Salida: ['Hello', 'World']
Al combinarlo con interval (o timer), zip puede utilizarse para emitir los valores de un Observable cada cierto tiempo. Ej: Emitir una cadena cada vez que interval emite (cada segundo)
import { from, interval, zip } from "rxjs";
import { map } from "rxjs/operators";
const framework$ = zip(from(["Angular", "React", "Vue"]), interval(1000)).pipe(
map(([framework]) => framework)
);
framework$.subscribe(console.log);
// Salida: (1s) Angular (1s) React (1s) Vue
Combinar la edad y el nombre de distintas fuentes
import { zip, of } from "rxjs";
import { map } from "rxjs/operators";
let age$ = of < number > (27, 25, 29);
let name$ = of < string > ("Foo", "Bar", "Beer");
let isDev$ = of < boolean > (true, true, false);
zip(age$, name$, isDev$)
.pipe(map(([age, name, isDev]) => ({ age, name, isDev })))
.subscribe((x) => console.log(x));
// Salida
// { age: 27, name: 'Foo', isDev: true }
// { age: 25, name: 'Bar', isDev: true }
// { age: 29, name: 'Beer', isDev: false }
zip(v1: O1, resultSelector: (v1: ObservedValueOf<O1>) => R): Observable<R>
v1 | Tipo: O1 . |
resultSelector | Tipo: (v1: ObservedValueOf) => R . |
Observable<R>
zip(v1: O1, v2: O2, resultSelector: (v1: ObservedValueOf<O1>, v2: ObservedValueOf<O2>) => R): Observable<R>
v1 | Tipo: O1 . |
v2 | Tipo: O2 . |
resultSelector | Tipo: (v1: ObservedValueOf, v2: ObservedValueOf) => R . |
Observable<R>
zip(v1: O1, v2: O2, v3: O3, resultSelector: (v1: ObservedValueOf<O1>, v2: ObservedValueOf<O2>, v3: ObservedValueOf<O3>) => R): Observable<R>
v1 | Tipo: O1 . |
v2 | Tipo: O2 . |
v3 | Tipo: O3 . |
resultSelector | Tipo: (v1: ObservedValueOf, v2: ObservedValueOf, v3: ObservedValueOf) => R . |
Observable<R>
zip(v1: O1, v2: O2, v3: O3, v4: O4, resultSelector: (v1: ObservedValueOf<O1>, v2: ObservedValueOf<O2>, v3: ObservedValueOf<O3>, v4: ObservedValueOf<O4>) => R): Observable<R>
v1 | Tipo: O1 . |
v2 | Tipo: O2 . |
v3 | Tipo: O3 . |
v4 | Tipo: O4 . |
resultSelector | Tipo: (v1: ObservedValueOf, v2: ObservedValueOf, v3: ObservedValueOf, v4: ObservedValueOf) => R . |
Observable<R>
zip(v1: O1, v2: O2, v3: O3, v4: O4, v5: O5, resultSelector: (v1: ObservedValueOf<O1>, v2: ObservedValueOf<O2>, v3: ObservedValueOf<O3>, v4: ObservedValueOf<O4>, v5: ObservedValueOf<O5>) => R): Observable<R>
v1 | Tipo: O1 . |
v2 | Tipo: O2 . |
v3 | Tipo: O3 . |
v4 | Tipo: O4 . |
v5 | Tipo: O5 . |
resultSelector | Tipo: (v1: ObservedValueOf, v2: ObservedValueOf, v3: ObservedValueOf, v4: ObservedValueOf, v5: ObservedValueOf) => R . |
Observable<R>
zip(v1: O1, v2: O2, v3: O3, v4: O4, v5: O5, v6: O6, resultSelector: (v1: ObservedValueOf<O1>, v2: ObservedValueOf<O2>, v3: ObservedValueOf<O3>, v4: ObservedValueOf<O4>, v5: ObservedValueOf<O5>, v6: ObservedValueOf<O6>) => R): Observable<R>
v1 | Tipo: O1 . |
v2 | Tipo: O2 . |
v3 | Tipo: O3 . |
v4 | Tipo: O4 . |
v5 | Tipo: O5 . |
v6 | Tipo: O6 . |
resultSelector | Tipo: (v1: ObservedValueOf, v2: ObservedValueOf, v3: ObservedValueOf, v4: ObservedValueOf, v5: ObservedValueOf, v6: ObservedValueOf) => R. |
Observable<R>
zip(v1: O1, v2: O2): Observable<[ObservedValueOf<O1>, ObservedValueOf<O2>]>
v1 | Tipo: O1 . |
v2 | Tipo: O2 . |
Observable<[ObservedValueOf<O1>, ObservedValueOf<O2>]>
zip(v1: O1, v2: O2, v3: O3): Observable<[ObservedValueOf<O1>, ObservedValueOf<O2>, ObservedValueOf<O3>]>
v1 | Tipo: O1 . |
v2 | Tipo: O2 . |
v3 | Tipo: O3 . |
Observable<[ObservedValueOf<O1>, ObservedValueOf<O2>, ObservedValueOf<O3>]>
zip(v1: O1, v2: O2, v3: O3, v4: O4): Observable<[ObservedValueOf<O1>, ObservedValueOf<O2>, ObservedValueOf<O3>, ObservedValueOf<O4>]>
v1 | Tipo: O1 . |
v2 | Tipo: O2 . |
v3 | Tipo: O3 . |
v4 | Tipo: O4 . |
Observable<[ObservedValueOf<O1>, ObservedValueOf<O2>, ObservedValueOf<O3>, ObservedValueOf<O4>]>
zip(v1: O1, v2: O2, v3: O3, v4: O4, v5: O5): Observable<[ObservedValueOfObservedValueOf<O4>, ObservedValueOf<O5>]>
v1 | Tipo: O1 . |
v2 | Tipo: O2 . |
v3 | Tipo: O3 . |
v4 | Tipo: O4 . |
v5 | Tipo: O5 . |
Observable<[ObservedValueOf<O1>, ObservedValueOf<O2>, ObservedValueOf<O3>, ObservedValueOf<O4>, ObservedValueOf<O5>]>
zip(v1: O1, v2: O2, v3: O3, v4: O4, v5: O5, v6: O6): Observable<[ObservedValueOf<O1>, ObservedValueOf<O2>, ObservedValueOf<O3>, ObservedValueOf<O4>, ObservedValueOf<O5>, ObservedValueOf<O6>]>
v1 | Tipo: O1 . |
v2 | Tipo: O2 . |
v3 | Tipo: O3 . |
v4 | Tipo: O4 . |
v5 | Tipo: O5 . |
v6 | Tipo: O6 . |
Observable<[ObservedValueOf<O1>, ObservedValueOf<O2>, ObservedValueOf<O3>, ObservedValueOf<O4>, ObservedValueOf<O5>, ObservedValueOf<O6>]>
zip(array: O[]): Observable<ObservedValueOf<O>[]>
array | Tipo: O[] . |
Observable<ObservedValueOf<O>[]>
zip(array: any[]): Observable<R>
array | Tipo: any[] . |
Observable<R>
zip(array: O[], resultSelector: (...values: ObservedValueOf<O>[]) => R): Observable<R>
array | Tipo: O[] . |
resultSelector | Tipo: (...values: ObservedValueOf[]) => R . |
Observable<R>
zip(array: any[], resultSelector: (...values: any[]) => R): Observable<R>
array | Tipo: any[] . |
resultSelector | Tipo: (...values: any[]) => R . |
Observable<R>
zip(...observables: O[]): Observable<ObservedValueOf<O>[]>
observables | Tipo: O[] . |
Observable<ObservedValueOf<O>[]>
zip(...observables: (O | ((...values: ObservedValueOf<O>[]) => R))[]): Observable<R>
observables | Tipo: (O | ((...values: ObservedValueOf[]) => R))[] . |
Observable<R>
zip(...observables: any[]): Observable<R>
observables | Tipo: any[] . |
Observable<R>
Documentación oficial en inglés