Skip to main content

Sharing Data with Subjects & BehaviorSubjects (RxJS) In angular

🚀 What are Subjects & BehaviorSubjects?

  • Subjects are special types of observables in RxJS that allow values to be multicasted to multiple observers.
  • BehaviorSubjects are a type of Subject that also holds the current value and emits it to new subscribers.

📦 Why Use Subjects & BehaviorSubjects?

Benefit Description
Multicasting Allows multiple subscribers to receive the same values.
State Management BehaviorSubjects hold the current value, useful for state management.
Flexibility Subjects can be used for various patterns like event handling, data sharing, etc.

🔥 Basic Example

Suppose you want to share data between components using a BehaviorSubject:

1. Create a Service with a BehaviorSubject

ng generate service data

This generates data.service.ts:

import { Injectable } from '@angular/core';
import { BehaviorSubject } from 'rxjs';

@Injectable({
  providedIn: 'root'
})
export class DataService {
  private dataSubject = new BehaviorSubject<any>(null);
  data$ = this.dataSubject.asObservable();

  updateData(data: any) {
    this.dataSubject.next(data);
  }
}

BehaviorSubject holds the current value and emits it to new subscribers.


2. Inject Service into Components

In app.component.ts:

import { Component, OnInit } from '@angular/core';
import { DataService } from './data.service';

@Component({
  selector: 'app-root',
  template: `
    <h1>Data: {{ data }}</h1>
    <button (click)="updateData()">Update Data</button>
  `
})
export class AppComponent implements OnInit {
  data: any;

  constructor(private dataService: DataService) {}

  ngOnInit() {
    this.dataService.data$.subscribe(data => {
      this.data = data;
    });
  }

  updateData() {
    this.dataService.updateData('New Data');
  }
}

In another.component.ts:

import { Component, OnInit } from '@angular/core';
import { DataService } from './data.service';

@Component({
  selector: 'app-another',
  template: `
    <h1>Another Component Data: {{ data }}</h1>
  `
})
export class AnotherComponent implements OnInit {
  data: any;

  constructor(private dataService: DataService) {}

  ngOnInit() {
    this.dataService.data$.subscribe(data => {
      this.data = data;
    });
  }
}

✅ Both components receive updates from the same BehaviorSubject.


📄 How Subjects & BehaviorSubjects Work Internally

  1. Subject Creation
    Subjects are created using new Subject() or new BehaviorSubject(initialValue).
  2. Subscription
    Observers subscribe to the Subject to receive values.
  3. Value Emission
    Values are emitted using subject.next(value).

🛠️ Types of Subjects

Type Description
Subject Basic multicasting observable.
BehaviorSubject Holds the current value and emits it to new subscribers.
ReplaySubject Emits a specified number of past values to new subscribers.
AsyncSubject Emits the last value to subscribers when the observable completes.

📚 Advanced: Using ReplaySubject

You can use ReplaySubject to emit a specified number of past values:

import { ReplaySubject } from 'rxjs';

const replaySubject = new ReplaySubject(2); // Emits the last 2 values

replaySubject.next('Value 1');
replaySubject.next('Value 2');
replaySubject.next('Value 3');

replaySubject.subscribe(value => console.log(value)); // Logs 'Value 2' and 'Value 3'

ReplaySubject is useful for scenarios where you need to replay past values to new subscribers.


📜 Summary

  • Subjects allow multicasting values to multiple observers.
  • BehaviorSubjects hold the current value and emit it to new subscribers.
  • RxJS provides various types of Subjects for different use cases.

Comments

Popular posts from this blog

Car Wash System vb.net

This software consists of a database that save the registration number of every vehicle being wash along side with the date, type of wash made and price Screen Shot Source Code To view records in the database: Dim conn As OleDbConnection = New OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=|DataDirectory|\washRcd.accdb;Persist Security Info=False") Dim sql As String sql = " SELECT * FROM tblwash" conn.Open() Dim dt As New DataTable Dim cmd2 As New OleDb.OleDbDataAdapter(sql, conn) cmd2.Fill(dt) DataGridView1.DataSource = dt DataGridView1.Refresh() conn.Close() To insert new record in the database: Private Sub insert() Dim conn As OleDbConnection = New OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=|DataDirectory|\washRcd.accdb;Persist Security Info=False") Dim updateSql As String = String.Format(...

Face recognition using EmguCV 3.0 and typing pattern recognition

Introduction An MSc project with the title Student Examination System, where the objective is to put the students in an examination condition but instead of having an invigilator in an examination center, the system will cater for the proper ongoing of the exam. the system can be used as an online examination system The system is able to: Recognizing the face shape of a particular student Detect if there is more than one person in the examination room  Analyze the typing pattern of a student and detect if any one person is taking part in the exam voice recognition for the student and detect if there is more than one person speaking in the examination room Setup Download Emgu CV from  http://www.emgu.com/wiki/index.php/Main_Page Download Haarcascade from  https://github.com/opencv/opencv/tree/master/data/haarcascades Create an account at  https://www.keytrac.net/ Face recognition The snippet below illustrates how the Emgu CV is loaded whe...

Google reCAPTCHA implementation - ASP.NET C#, ASP.NET Web API, Android

Google reCAPTCHA implementation ASP.NET C# Steps to implement Google reCAPTCHA in your website using technologies such as ASP.NET C#, ASP.NET web API, HTML and javascript. First you need to use your google account to login to Google reCAPTCHA  to register a new site. Add a label of your choice in the label section and for web implementation select the reCAPTCHA V2 radio button. Next in the domain section you can add several domains, for testing purposes you can add localhost also followed by another domain in the next line. Accept the terms and conditions and click on the button register. After you click register, google will generate a site key and a secret key and  instructions how to integrate it on both client and server side. Create ASP.NET Web API Next step is to open Microsoft Visual Studio and create a new project by selecting File > New from the menu bar and then select Project.  Select ASP.NET Web Application(.NET Framework) in the p...