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.

Keluaran