RxJS - Bekerja dengan Subjek
Subjek adalah sebuah observasi yang dapat multicast yaitu berbicara dengan banyak pengamat. Misalnya tombol dengan event listener, fungsi yang dilampirkan ke event menggunakan add listener dipanggil setiap kali pengguna mengklik tombol, fungsi serupa juga berlaku untuk subjek.
Kami akan membahas topik berikut di bab ini -
- Buat subjek
- Apa Perbedaan antara Teramati dan Subjek?
- Subjek Perilaku
- Putar Ulang Subjek
- AsyncSubject
Buat subjek
Untuk bekerja dengan subjek, kita perlu mengimpor Subjek seperti yang ditunjukkan di bawah ini -
import { Subject } from 'rxjs';
Anda dapat membuat objek subjek sebagai berikut -
const subject_test = new Subject();
Objek adalah pengamat yang memiliki tiga metode -
- next(v)
- error(e)
- complete()
Berlangganan ke Subjek
Anda dapat membuat beberapa langganan pada subjek seperti yang ditunjukkan di bawah ini -
subject_test.subscribe({
next: (v) => console.log(`From Subject : ${v}`)
});
subject_test.subscribe({
next: (v) => console.log(`From Subject: ${v}`)
});
Langganan terdaftar ke objek subjek seperti addlistener yang kita bahas sebelumnya.
Meneruskan Data ke Subjek
Anda bisa meneruskan data ke subjek yang dibuat menggunakan metode next ().
subject_test.next("A");
Data akan diteruskan ke semua langganan yang ditambahkan pada subjek.
Contoh
Berikut, adalah contoh kerja dari subjek -
import { Subject } from 'rxjs';
const subject_test = new Subject();
subject_test.subscribe({
next: (v) => console.log(`From Subject : ${v}`)
});
subject_test.subscribe({
next: (v) => console.log(`From Subject: ${v}`)
});
subject_test.next("A");
subject_test.next("B");
Objek subject_test dibuat dengan memanggil Subjek baru (). Objek subject_test memiliki referensi ke metode next (), error (), dan complete (). Output dari contoh di atas ditunjukkan di bawah ini -
Keluaran
Kita bisa menggunakan metode complete () untuk menghentikan eksekusi subjek seperti yang ditunjukkan di bawah ini.
Contoh
import { Subject } from 'rxjs';
const subject_test = new Subject();
subject_test.subscribe({
next: (v) => console.log(`From Subject : ${v}`)
});
subject_test.subscribe({
next: (v) => console.log(`From Subject: ${v}`)
});
subject_test.next("A");
subject_test.complete();
subject_test.next("B");
Setelah kita memanggil selesai, metode selanjutnya yang dipanggil nanti tidak dipanggil.
Keluaran
Sekarang mari kita lihat cara memanggil metode error ().
Contoh
Di bawah ini adalah contoh yang berfungsi -
import { Subject } from 'rxjs';
const subject_test = new Subject();
subject_test.subscribe({
error: (e) => console.log(`From Subject : ${e}`)
});
subject_test.subscribe({
error: (e) => console.log(`From Subject : ${e}`)
});
subject_test.error(new Error("There is an error"));
Keluaran
Apa Perbedaan antara Teramati dan Subjek?
Sebuah observable akan berbicara satu sama lain, dengan pelanggan. Setiap kali Anda berlangganan observable, eksekusi akan dimulai dari awal. Terima panggilan Http yang dilakukan menggunakan ajax, dan 2 pelanggan memanggil observable. Anda akan melihat 2 permintaan HttpHttp di tab jaringan browser.
Contoh
Berikut adalah contoh kerja yang sama -
import { ajax } from 'rxjs/ajax';
import { map } from 'rxjs/operators';
let final_val = ajax('https://jsonplaceholder.typicode.com/users').pipe(map(e => e.response));
let subscriber1 = final_val.subscribe(a => console.log(a));
let subscriber2 = final_val.subscribe(a => console.log(a));
Keluaran
Sekarang, di sini masalahnya adalah, kami ingin data yang sama dibagikan, tetapi tidak, dengan biaya 2 panggilan Http. Kami ingin melakukan satu panggilan Http dan berbagi data antar pelanggan.
Ini akan dimungkinkan dengan menggunakan Subjek. Ini adalah sebuah observasi yang dapat multicast yaitu berbicara dengan banyak pengamat. Itu dapat berbagi nilai di antara pelanggan.
Contoh
Berikut adalah contoh kerja menggunakan Subjek -
import { Subject } from 'rxjs';
import { ajax } from 'rxjs/ajax';
import { map } from 'rxjs/operators';
const subject_test = new Subject();
subject_test.subscribe({
next: (v) => console.log(v)
});
subject_test.subscribe({
next: (v) => console.log(v)
});
let final_val = ajax('https://jsonplaceholder.typicode.com/users').pipe(map(e => e.response));
let subscriber = final_val.subscribe(subject_test);
Keluaran
Sekarang Anda hanya dapat melihat satu panggilan Http dan data yang sama dibagikan di antara pelanggan yang dipanggil.
Subjek Perilaku
Subjek perilaku akan memberi Anda nilai terbaru saat dipanggil.
Anda dapat membuat subjek perilaku seperti yang ditunjukkan di bawah ini -
import { BehaviorSubject } from 'rxjs';
const subject = new BehaviorSubject("Testing Behaviour Subject");
// initialized the behaviour subject with value:Testing Behaviour Subject
Contoh
Berikut adalah contoh kerja untuk menggunakan Behavior Subject -
import { BehaviorSubject } from 'rxjs';
const behavior_subject = new BehaviorSubject("Testing Behaviour Subject");
// 0 is the initial value
behavior_subject.subscribe({
next: (v) => console.log(`observerA: ${v}`)
});
behavior_subject.next("Hello");
behavior_subject.subscribe({
next: (v) => console.log(`observerB: ${v}`)
});
behavior_subject.next("Last call to Behaviour Subject");
Keluaran
Putar Ulang Subjek
Sebuah replaysubject mirip dengan subjek perilaku, di mana, ia dapat menyangga nilai-nilai dan memutar ulang hal yang sama ke pelanggan baru.
Contoh
Berikut adalah contoh kerja subjek ulangan -
import { ReplaySubject } from 'rxjs';
const replay_subject = new ReplaySubject(2);
// buffer 2 values but new subscribers
replay_subject.subscribe({
next: (v) => console.log(`Testing Replay Subject A: ${v}`)
});
replay_subject.next(1);
replay_subject.next(2);
replay_subject.next(3);
replay_subject.subscribe({
next: (v) => console.log(`Testing Replay Subject B: ${v}`)
});
replay_subject.next(5);
Nilai buffer yang digunakan adalah 2 pada subjek ulangan. Jadi dua nilai terakhir akan di-buffer dan digunakan untuk pelanggan baru yang dipanggil.
Keluaran
AsyncSubject
Dalam kasus AsyncSubject, nilai terakhir yang dipanggil diteruskan ke pelanggan dan itu akan dilakukan hanya setelah metode complete () dipanggil.
Contoh
Berikut adalah contoh kerja yang sama -
import { AsyncSubject } from 'rxjs';
const async_subject = new AsyncSubject();
async_subject.subscribe({
next: (v) => console.log(`Testing Async Subject A: ${v}`)
});
async_subject.next(1);
async_subject.next(2);
async_subject.complete();
async_subject.subscribe({
next: (v) => console.log(`Testing Async Subject B: ${v}`)
});
Di sini, sebelum selesai disebut nilai terakhir yang diteruskan ke subjek adalah 2 dan sama dengan yang diberikan kepada pelanggan.