首页 > 其他分享 >关于 Angular 应用开发里 Subject 和 BehaviorSubject 的用法一例

关于 Angular 应用开发里 Subject 和 BehaviorSubject 的用法一例

时间:2023-09-08 18:55:08浏览次数:37  
标签:订阅 BehaviorSubject import message MessageCenterService Angular Subject

笔者一直在 SAP 中国研究院从事 Commerce Cloud 这款 Angular 应用的开发,最近工作中修复了一个 bug.

在 Spartacus UI 上点击 Create 按钮之后:

维护 User 的明细数据,然后点击 Save 按钮:

点击之后,我们期望的结果是收到一条 用户成功创建的提示消息,并且页面自动导航回到点击 Create 按钮的页面。但 bug 修复之前,并没有成功创建的提示消息。

我们在 Github 这个 PR里修复了该问题。在解决方案里使用到了 Rxjs 的 Subject,我也顺带了解了 Subject 和 BehaviorSubject 的区别,本文将我的学习记录如下。

在 Angular 开发中,RxJS 是一个非常重要的库,它提供了强大的响应式编程工具,用于处理异步操作和数据流。Subject 是 RxJS 中的一个关键工具,它是一种特殊类型的 Observable,同时也可以被用于触发和监听事件,是实现事件总线的一种方式。BehaviorSubject 则是 Subject 的一个变种,它在 Subject 的基础上增加了初始值和记忆功能。

Subject 的特点和用法:

Subject 是一个多播的 Observable,它既是观察者也是可观察对象。这意味着我们可以通过 subscribe 方法订阅它,也可以通过 next 方法向它发送新值。Subject 会将这些值广播给所有订阅者。它通常用于实现事件总线、广播事件、多播数据流等场景。不过需要注意,Subject 在新的订阅者订阅时,不会向其发送之前发送的值。

BehaviorSubject 的特点和用法:

BehaviorSubject 继承自 Subject,在 Subject 的基础上增加了初始值和记忆功能。这意味着在 BehaviorSubject 被订阅时,它会发送其当前的值给订阅者。而当新的值通过 next 方法发送时,它会广播给所有订阅者,也会被记忆为新的当前值,以供新的订阅者使用。因此,BehaviorSubject 适用于需要初始值和对新订阅者广播最新值的情况。

现在,让我们通过一个详细的示例来说明 SubjectBehaviorSubject 的用法和区别。

示例场景:

假设我们正在开发一个实时聊天应用,我们需要一个消息中心来接收和分发聊天消息。我们可以使用 SubjectBehaviorSubject 来实现这个消息中心。让我们分别考虑这两种实现方式。

使用 Subject 实现消息中心:

首先,我们定义一个 MessageCenterService,其中包含一个 Subject 用于接收和分发消息:

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

@Injectable({
  providedIn: 'root'
})
export class MessageCenterService {
  private messageSubject = new Subject<string>();

  sendMessage(message: string): void {
    this.messageSubject.next(message);
  }

  getMessage(): Subject<string> {
    return this.messageSubject;
  }
}

在聊天界面组件中,我们订阅消息中心的 Subject 来接收和显示聊天消息:

import { Component, OnDestroy } from '@angular/core';
import { MessageCenterService } from './message-center.service';
import { Subscription } from 'rxjs';

@Component({
  selector: 'app-chat',
  template: `
    <div *ngFor="let message of messages">{{ message }}</div>
  `
})
export class ChatComponent implements OnDestroy {
  messages: string[] = [];
  subscription: Subscription;

  constructor(private messageCenter: MessageCenterService) {
    this.subscription = this.messageCenter.getMessage().subscribe(message => {
      this.messages.push(message);
    });
  }

  ngOnDestroy(): void {
    this.subscription.unsubscribe();
  }
}

使用 BehaviorSubject 实现消息中心:

现在,我们将 Subject 替换为 BehaviorSubject 来实现带有记忆功能的消息中心:

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

@Injectable({
  providedIn: 'root'
})
export class MessageCenterService {
  private messageSubject = new BehaviorSubject<string>('Welcome to the chat');

  sendMessage(message: string): void {
    this.messageSubject.next(message);
  }

  getMessage(): BehaviorSubject<string> {
    return this.messageSubject;
  }
}

同样,我们在聊天界面组件中订阅消息中心的 BehaviorSubject 来接收和显示聊天消息:

import { Component, OnDestroy } from '@angular/core';
import { MessageCenterService } from './message-center.service';
import { Subscription } from 'rxjs';

@Component({
  selector: 'app-chat',
  template: `
    <div *ngFor="let message of messages">{{ message }}</div>
  `
})
export class ChatComponent implements OnDestroy {
  messages: string[] = [];
  subscription: Subscription;

  constructor(private messageCenter: MessageCenterService) {
    this.subscription = this.messageCenter.getMessage().subscribe(message => {
      this.messages.push(message);
    });
  }

  ngOnDestroy(): void {
    this.subscription.unsubscribe();
  }
}

总结:

SubjectBehaviorSubject 都是 RxJS 中用于处理异步事件和数据流的强大工具。Subject 用于实现事件总线和多播数据流,而 BehaviorSubjectSubject 的基础上增加了初始值和记忆功能。在实际开发中,根据具体的需求,我们可以选择合适的工具来实现不同的功能。

标签:订阅,BehaviorSubject,import,message,MessageCenterService,Angular,Subject
From: https://www.cnblogs.com/sap-jerry/p/17688350.html

相关文章

  • 什么是 Angular 应用 angular.json 中的 assets 数组
    在Angular项目中,angular.json是一个非常重要的配置文件,用于定义和管理项目的各种设置和构建选项。其中,assets数组是angular.json中的一个关键配置项,用于指定需要在构建后包含在应用程序中的静态资源文件和文件夹。在本文中,我将解释什么是assets数组,并提供详细示例来说明如何使用它......
  • 【记录】Angular 中使用 eChart
    使用echart,要注意版本的对应关系v16.xforAngular>=16v15.xforAngular>=15v14.xforAngular>=14v8.xforAngular>=13v7.xforAngular>=11v6.xforAngular>=10,<11v5.xforAngular>=6,<10v2.3.1forAngular<6该项目的开......
  • 二级医院信息系统源码(HIS) Angular+Nginx+ Java
    基层医疗云HIS作为基于云计算的B/S构架的HIS系统,为基层医疗机构提供了标准化的、信息化的、可共享的医疗信息管理系统,可有效进行医疗数据共享与交换,解决数据重复采集及信息孤岛等问题,实现对基层医疗数据的分析和挖掘,为基层卫生机构提供科学合理的业务管理服务。可实现“云部署”,即......
  • 如何创建一个数据交互的Angular应用程序?这个工具不要错过!(二)
    在上文中(点击这里回顾>>),我们介绍了如何使用KendoUIforAngular完成一个Angular应用的数据交互功能创建,其中涉及到了内置的数据方法、场景等,本文将继续介绍剩下的部分。PS:给大家推荐一个实用组件~KendoUIforAngular是专业级的AngularUI组件库,不仅是将其他供应商提供的现有组......
  • 用 Visual Studio Code 开发 Angular 应用自动生成的 .angular 文件夹
    在Angular开发中,项目根目录下的.angular文件夹是AngularCLI工具的一部分,它包含了一些配置和缓存文件,用于提高开发效率和构建性能。.angular文件夹的作用主要包括:缓存构建信息:.angular文件夹中包含了一些缓存文件,用于存储先前构建的信息,以加速后续的构建过程。这有助于......
  • Angular 实现分页器组件
    很感谢 angular实现简单的pagination分页组件-Amor丶Diamond-博客园(cnblogs.com) ,我根据这位博主代码做了修改,增加了跳转和每页行数功能.先看图:  //可配置项//totalItem数据总条数//maxSize:最多显示几页//pageSizes:行/页//moreBtn:是否显示......
  • angular - HttpClient
    入门引入HttpClientModule模块//app.module.tsimport{HttpClientModule}from'@angular/common/http';@NgModule({imports:[HttpClientModule],})注入服务实例import{HttpClient}from'@angular/common/http';exportclassAppC......
  • 关于 Angular 应用开发里 Subject 和 BehaviorSubject 的用法一例
    笔者一直在SAP中国研究院从事CommerceCloud这款Angular应用的开发,最近工作中修复了一个bug.在SpartacusUI上点击Create按钮之后:维护User的明细数据,然后点击Save按钮:点击之后,我们期望的结果是收到一条用户成功创建的提示消息,并且页面自动导航回到点击Create......
  • 【Angular】 在组件内使用生命周期钩子函数如 OnDestroy 时,必须先 implements 么?
    不是必须,就算不implements,它也能被成功识别为生命周期钩子函数。但是最佳实践建议加入implements,可以增加钩子函数的数据类型检查,以及阻止某些因为未加入implements导致的错误。参考:AngularLifecycleInterfaceOnChangesshouldbeimplementedformethodngOnChanges......
  • 【Angular】Angular的Service什么时候被销毁?
    当ServiceA被声明在Moudule里时,模块里所有组件、管道、指令拥有同一个ServiceA的实例,当第一个需要注入该ServiceA的组件、管道、指令实例化A后,后面再需要注入ServiceA时,用的是同一个实例。当Moudle被销毁(通常是该模块的页面被卸载)后,ServiceA同步被销毁。当ServiceA被声明......