Rumah  >  Artikel  >  hujung hadapan web  >  Perbezaan antara mergeMap lwn switchMap lwn concatMap lwn exhaustMap

Perbezaan antara mergeMap lwn switchMap lwn concatMap lwn exhaustMap

王林
王林asal
2024-09-03 14:48:481108semak imbas

Hai, dalam temu bual anda sebagai pembangun Angular, anda mungkin ditanya beberapa soalan tentang pengendali RxJs dan perbezaannya.

Salah satu soalan yang paling biasa ialah "Apakah perbezaan antara mergeMap vs switchMap vs concatMap vs exhaustMap?"

Mari kita mendalaminya dan menerangkannya secara ringkas.

Saya akan menerangkan perbezaan tingkah laku menggunakan satu contoh mudah:

import { interval, take, tap, from } from 'rxjs';
import {
  switchMap,
  mergeMap,
  concatMap,
  exhaustMap,
} from 'rxjs/operators';

const mapOperators = [
  mergeMap,
  switchMap,
  concatMap,
  exhaustMap
];

const selectedMap = mapOperators[0]; // <- Change operator index here

const clicks$ = from(['First Click', 'Second Click', 'Third Click']).pipe(
  tap(console.log),
);

clicks$
  .pipe(
    selectedMap((click: number) =>
      interval(500).pipe(
        tap((intervalValue: number) =>
          console.log(
            `${click} Value: ${intervalValue}`
          )
        ),
        take(3)
      )
    )
  )
  .subscribe();

Dalam contoh kod, yang anda boleh bereksperimen dengan Stackblitz, anda boleh melihat tiruan 3 klik pengguna

Sekarang, mari lihat apa yang akan dikembalikan oleh setiap pengendali

MergeMap

Difference between mergeMap vs switchMap vs concatMap vs exhaustMap

First Click
Second Click
Third Click
First Click Value: 0
Second Click Value: 0
Third Click Value: 0
First Click Value: 1
Second Click Value: 1
Third Click Value: 1
First Click Value: 2
Second Click Value: 2
Third Click Value: 2

Pengendali mergeMap menjalankan pelepasan secara selari, itulah sebabnya anda melihat

First Click Value: 0
Second Click Value: 0
Third Click Value: 0

dengan nilai 0

Peta Tukar

Difference between mergeMap vs switchMap vs concatMap vs exhaustMap

First Click
Second Click
Third Click
Third Click Value: 0
Third Click Value: 1
Third Click Value: 2

Pengendali switchMap akan membatalkan yang sebelumnya selepas setiap klik baharu, dalam kes kami Klik Pertama akan dibatalkan oleh Klik Kedua dan Klik Kedua akan dibatalkan oleh Klik Ketiga dan sebagai hasilnya kita akan melihat Nilai Klik Ketiga

Third Click Value: 0
Third Click Value: 1
Third Click Value: 2

ConcatMap

Difference between mergeMap vs switchMap vs concatMap vs exhaustMap

First Click
Second Click
Third Click
First Click Value: 0
First Click Value: 1
First Click Value: 2
Second Click Value: 0
Second Click Value: 1
Second Click Value: 2
Third Click Value: 0
Third Click Value: 1
Third Click Value: 2

Pengendali concatMap akan menghafal semua klik dan konsol.log mereka dalam susunan yang sama, dalam kes kami Klik Pertama, Klik Kedua, Klik Ketiga sebagai anda lihat dalam konsol

First Click Value: 0
First Click Value: 1
First Click Value: 2
Second Click Value: 0
Second Click Value: 1
Second Click Value: 2
Third Click Value: 0
Third Click Value: 1
Third Click Value: 2

Peta Ekzos

Difference between mergeMap vs switchMap vs concatMap vs exhaustMap

First Click
Second Click
Third Click
First Click Value: 0
First Click Value: 1
First Click Value: 2

Pengendali exhaustMap akan menyekat strim sehingga Klik Pertama selesai dan dalam kes kami Klik Kedua dan Klik Ketiga akan diabaikan

First Click Value: 0
First Click Value: 1
First Click Value: 2

Sekarang anda memahami perbezaan antara pengendali ini, anda boleh bayangkan akibat daripada memilih yang salah

Atas ialah kandungan terperinci Perbezaan antara mergeMap lwn switchMap lwn concatMap lwn exhaustMap. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn