RxJS - Operator
Operator adalah bagian penting dari RxJS. Operator adalah fungsi murni yang menerima observasi sebagai input dan output juga dapat diamati.
Bekerja dengan Operator
Operator adalah fungsi murni yang menerima observasi sebagai input dan output juga dapat diamati.
Untuk bekerja dengan operator kita membutuhkan metode pipa ().
Contoh penggunaan pipa ()
let obs = of(1,2,3); // an observable
obs.pipe(
operator1(),
operator2(),
operator3(),
operator3(),
)
Dalam contoh di atas kami telah membuat observable menggunakan of()metode yang mengambil nilai 1, 2 dan 3. Sekarang pada observasi ini Anda dapat melakukan operasi yang berbeda menggunakan sejumlah operator menggunakan metode pipa () seperti yang ditunjukkan di atas. Eksekusi operator akan berlanjut secara berurutan pada yang dapat diamati.
Di bawah ini adalah contoh yang berfungsi -
import { of } from 'rxjs';
import { map, reduce, filter } from 'rxjs/operators';
let test1 = of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);
let case1 = test1.pipe(
filter(x => x % 2 === 0),
reduce((acc, one) => acc + one, 0)
)
case1.subscribe(x => console.log(x));
Keluaran
30
Dalam contoh di atas, kami telah menggunakan operator filter itu, memfilter angka genap dan, selanjutnya kami telah menggunakan reduce() operator yang akan menambahkan nilai genap dan memberikan hasil saat berlangganan.
Berikut adalah daftar Observable yang akan kita bahas.
- Creation
- Mathematical
- Join
- Transformation
- Filtering
- Utility
- Conditional
- Multicasting
- Penanganan kesalahan
Operator Penciptaan
Berikut adalah operator yang akan kita diskusikan dalam kategori Operator penciptaan -
Sr Tidak | Operator & Deskripsi |
---|---|
1 | ajax Operator ini akan membuat permintaan ajax untuk URL yang diberikan. |
2 | dari Operator ini akan membuat sebuah observable dari sebuah array, sebuah objek seperti array, sebuah janji, sebuah objek yang dapat diulang, atau sebuah objek seperti yang dapat diamati. |
3 | fromEvent Operator ini akan memberikan output berupa observable yang akan digunakan pada elemen yang mengeluarkan event misalnya tombol, klik, dll. |
4 | fromEventPattern Operator ini akan membuat observable dari fungsi input yang digunakan untuk meregistrasi event handler. |
5 | selang Operator ini akan membuat Observable untuk setiap waktu selama waktu yang ditentukan .. |
6 | dari Operator ini akan menerima argumen yang diteruskan dan mengubahnya menjadi dapat diamati. |
7 | jarak Operator ini akan membuat Observable yang akan memberi Anda urutan angka berdasarkan rentang yang disediakan. |
8 | throwError Operator ini akan membuat observable yang akan memberi tahu kesalahan. |
9 | timer Operator ini akan membuat observable yang akan memancarkan nilai setelah batas waktu dan nilainya akan terus meningkat setelah setiap panggilan. |
10 | iif Operator ini akan memutuskan Observable mana yang akan berlangganan. |
Operator Matematika
Berikut ini adalah operator yang akan kita diskusikan dalam kategori Operator matematika -
Sr Tidak | Operator & Deskripsi |
---|---|
1 | Menghitung Operator count () mengambil Observable dengan nilai dan mengubahnya menjadi Observable yang akan memberikan nilai tunggal |
2 | Max Metode Max akan menerima sebuah observable dengan semua nilai dan mengembalikan sebuah observable dengan nilai max |
3 | Min Metode min akan mengambil sebuah observable dengan semua nilai dan mengembalikan sebuah observable dengan nilai min. |
4 | Mengurangi Dalam operator reduce, fungsi akumulator digunakan pada input yang dapat diamati, dan fungsi akumulator akan mengembalikan nilai yang terakumulasi dalam bentuk yang dapat diamati, dengan nilai benih opsional yang diteruskan ke fungsi akumulator. Fungsi reduce () akan mengambil 2 argumen, satu fungsi akumulator, dan kedua nilai seed. |
Bergabunglah dengan Operator
Berikut ini adalah operator yang akan kita diskusikan dalam kategori Bergabung dengan operator.
Sr Tidak | Operator & Deskripsi |
---|---|
1 | concat Operator ini akan secara berurutan memancarkan Observable yang diberikan sebagai input dan melanjutkan ke yang berikutnya. |
2 | garpuGabung Operator ini akan diambil dalam array atau objek dict sebagai input dan akan menunggu observable selesai dan mengembalikan nilai terakhir yang dipancarkan dari observable yang diberikan. |
3 | menggabungkan Operator ini akan mengambil input yang dapat diamati dan akan memancarkan semua nilai dari yang dapat diamati dan memancarkan satu keluaran tunggal yang dapat diamati. |
4 | ras Ini akan memberikan kembali sebuah observasi yang akan menjadi salinan cermin dari sumber pertama yang dapat diamati. |
Operator Transformasi
Berikut ini adalah operator yang akan kita diskusikan dalam kategori operator Transformasi.
Sr Tidak | Operator & Deskripsi |
---|---|
1 | penyangga Buffer beroperasi pada yang dapat diamati dan menganggap argumen sebagai yang dapat diamati. Ini akan mulai buffering nilai-nilai yang dipancarkan pada observable aslinya dalam sebuah array dan akan memancarkan hal yang sama ketika observable diambil sebagai argumen, dipancarkan. Setelah observable diambil sebagai argumen yang dipancarkan, buffer di-reset dan mulai buffering lagi pada aslinya sampai input yang dapat diamati memancarkan dan skenario yang sama berulang. |
2 | bufferCount Dalam kasus operator buffercount (), ia akan mengumpulkan nilai-nilai dari observable tempat ia dipanggil dan memancarkan yang sama ketika ukuran buffer yang diberikan ke buffercount cocok. |
3 | bufferTime Ini mirip dengan bufferCount, jadi di sini, ini akan mengumpulkan nilai-nilai dari observable yang memanggilnya dan memancarkan bufferTimeSpan selesai. Dibutuhkan dalam 1 argumen yaitu bufferTimeSpan . |
4 | bufferToggle Dalam kasus bufferToggle () dibutuhkan 2 argumen, openings dan closingSelector. Argumen pembuka adalah subscribe atau janji untuk memulai buffer dan argumen kedua closingSelector lagi-lagi bisa dijadikan subscribe atau menjanjikan indikator untuk menutup buffer dan memancarkan nilai yang dikumpulkan. |
5 | bufferWhen Operator ini akan memberikan nilai dalam bentuk array, yang dibutuhkan dalam satu argumen sebagai fungsi yang akan memutuskan kapan harus menutup, mengeluarkan dan mengatur ulang buffer. |
6 | memperluas Operator perluasan mengambil fungsi sebagai argumen yang diterapkan pada sumber yang dapat diamati secara rekursif dan juga pada keluaran yang dapat diamati. Nilai akhir dapat diamati. |
7 | groupBy Dalam operator groupBy, output dikelompokkan berdasarkan kondisi tertentu dan item grup ini dipancarkan sebagai GroupedObservable. |
8 | peta Dalam kasus operator peta, fungsi proyek diterapkan pada setiap nilai pada sumber Observable dan keluaran yang sama dipancarkan sebagai Observable. |
9 | mapTo Nilai konstan diberikan sebagai output bersama dengan Observable setiap kali sumber Observable mengeluarkan nilai. |
10 | mergeMap Dalam kasus operator mergeMap, fungsi proyek diterapkan pada setiap nilai sumber dan keluarannya digabungkan dengan keluaran Observable. |
11 | switchMap Dalam kasus operator switchMap, fungsi proyek diterapkan pada setiap nilai sumber dan keluarannya digabungkan dengan keluaran Observable, dan nilai yang diberikan adalah yang diproyeksikan terbaru. |
12 | jendela Dibutuhkan argumen batas jendela yang dapat diamati dan memberikan kembali pengamatan bersarang setiap kali batas jendela yang diberikan memancarkan |
Operator Filter
Berikut ini adalah operator yang akan kita diskusikan dalam kategori operator filtering.
Sr Tidak | Operator & Deskripsi |
---|---|
1 | debounce Nilai yang dipancarkan dari sumber Dapat diamati setelah beberapa saat dan emisi ditentukan oleh masukan lain yang diberikan sebagai Dapat diamati atau dijanjikan. |
2 | debounceTime Ini akan memancarkan nilai dari sumber yang dapat diamati hanya setelah waktu selesai. |
3 | berbeda Operator ini akan memberikan semua nilai dari sumber yang dapat diamati yang berbeda jika dibandingkan dengan nilai sebelumnya. |
4 | elementAt Operator ini akan memberikan nilai tunggal dari sumber yang dapat diamati berdasarkan indeks yang diberikan. |
5 | Saring Operator ini akan memfilter nilai-nilai dari sumber yang dapat diamati berdasarkan fungsi predikat yang diberikan. |
6 | pertama Operator ini akan memberikan nilai pertama yang dipancarkan oleh sumber Observable. |
7 | terakhir Operator ini akan memberikan nilai terakhir yang dipancarkan oleh sumber Observable. |
8 | ignoreElements Operator ini akan mengabaikan semua nilai dari sumber Observable dan hanya mengeksekusi panggilan untuk menyelesaikan atau melakukan kesalahan fungsi callback. |
9 | Sampel Operator ini akan memberikan nilai terbaru dari sumber Observable, dan hasilnya akan bergantung pada argumen yang diteruskan kepadanya. |
10 | melewatkan Operator ini akan mengembalikan sebuah observasi yang akan melewatkan kejadian pertama dari item hitungan yang diambil sebagai input. |
11 | mencekik Operator ini akan mengeluarkan serta mengabaikan nilai dari sumber yang dapat diamati untuk waktu yang ditentukan oleh fungsi masukan yang diambil sebagai argumen dan proses yang sama akan diulang. |
Operator Utilitas
Berikut ini adalah operator yang akan kita diskusikan dalam kategori operator utilitas.
Sr Tidak | Operator & Deskripsi |
---|---|
1 | keran Operator ini akan memiliki keluaran, sama dengan sumber yang dapat diamati, dan dapat digunakan untuk mencatat nilai ke pengguna dari yang dapat diamati. Nilai utama, kesalahan jika ada atau jika tugas selesai. |
2 | menunda Operator ini menunda nilai yang dipancarkan dari sumber Observable berdasarkan waktu tunggu yang diberikan. |
3 | delayWhen Operator ini menunda nilai yang dipancarkan dari sumber Observable berdasarkan batas waktu dari observasi lain yang diambil sebagai input. |
4 | observasi Operator ini berdasarkan penjadwal input akan mengirimkan kembali notifikasi dari sumber Observable. |
5 | subscribeOn Operator ini membantu pelanggan asynchronous ke sumber Observable berdasarkan penjadwal yang diambil sebagai input. |
6 | jarak waktu Operator ini akan mengembalikan objek yang berisi nilai saat ini dan waktu yang telah berlalu antara nilai saat ini dan sebelumnya yang dihitung menggunakan input penjadwal yang diambil. |
7 | cap waktu Mengembalikan stempel waktu bersama dengan nilai yang dipancarkan dari sumber Observable yang menceritakan tentang waktu ketika nilai itu dipancarkan. |
8 | waktu habis Operator ini akan memunculkan kesalahan jika sumber yang Dapat Diobservasi tidak mengeluarkan nilai setelah waktu tunggu yang ditentukan. |
9 | toArray Mengumpulkan semua nilai sumber dari Observable dan mengeluarkannya sebagai larik saat sumber selesai. |
Operator Bersyarat
Berikut ini adalah operator yang akan kita diskusikan dalam kategori operator bersyarat.
Sr Tidak | Operator & Deskripsi |
---|---|
1 | defaultIfEmpty Operator ini akan mengembalikan nilai default jika observasi sumber kosong. |
2 | setiap Ini akan mengembalikan Observable berdasarkan fungsi input yang memenuhi kondisi pada setiap nilai pada sumber Observable. |
3 | Temukan Ini akan mengembalikan observable ketika nilai pertama sumber Observable memenuhi kondisi untuk fungsi predikat yang diambil sebagai input. |
4 | findIndex Operator ini berdasarkan penjadwal input akan mengirimkan kembali notifikasi dari sumber Observable. |
5 | kosong Operator ini akan memberikan output sebagai true jika input observable menjalankan callback lengkap tanpa memancarkan nilai apa pun dan false jika input observable memancarkan nilai apa pun. |
Operator Multicasting
Berikut ini adalah operator yang akan kita bahas dalam kategori operator multicasting ..
Sr Tidak | Operator & Deskripsi |
---|---|
1 | multicast Operator multicast membagikan satu langganan yang dibuat dengan pelanggan lain. Parameter yang diambil multicast, adalah subjek atau metode pabrik yang mengembalikan metode ConnectableObservable yang memiliki metode connect (). Untuk berlangganan, metode connect () harus dipanggil. |
2 | menerbitkan Operator ini memberikan kembali ConnectableObservable dan perlu menggunakan metode connect () untuk berlangganan observable. |
3 | publishBehavior publishBehaviour menggunakan BehaviourSubject, dan mengembalikan ConnectableObservable. Metode connect () harus digunakan untuk berlangganan observasi yang dibuat. |
4 | publishLast publishBehaviour menggunakan AsyncSubject, dan mengembalikan ConnectableObservable. Metode connect () harus digunakan untuk berlangganan observasi yang dibuat. |
5 | publishReplay publishReplay menggunakan subjek perilaku di mana ia dapat menyangga nilai dan memutar ulang hal yang sama ke pelanggan baru dan mengembalikan ConnectableObservable. Metode connect () harus digunakan untuk berlangganan observasi yang dibuat. |
6 | Bagikan Ini adalah alias untuk operator mutlicast () dengan satu-satunya perbedaan adalah Anda tidak perlu memanggil metode connect () secara manual untuk memulai langganan. |
Operator Penanganan Kesalahan
Berikut ini adalah operator yang akan kita bahas dalam kategori operator penanganan kesalahan.
Sr Tidak | Operator & Deskripsi |
---|---|
1 | catchError Operator ini menangani kesalahan penangkapan pada sumber Observable dengan mengembalikan Observable baru atau error. |
2 | mencoba kembali Operator ini akan melakukan percobaan ulang ke sumber yang dapat diamati jika ada kesalahan dan percobaan ulang akan dilakukan berdasarkan jumlah masukan yang diberikan. |