Angular RxJS Subject主体

本文详细介绍了RxJS中Subject与Observable的区别。Subject是多播的,可以将数据推送给多个订阅者,而Observable则是单播的。通过示例展示了Subject如何作为可观察对象向多个观察者发送数据,以及Subject如何作为观察者订阅Observable并传递数据给其他订阅者。理解这些概念对于掌握RxJS的响应式编程至关重要。
摘要由CSDN通过智能技术生成

Subject与Observable的区别

  1. Subject是多播的,可以把值推送给多个观察者;Observable是单播的。
  2. Subject既可以做可观察对象,又可以做观察者

Subject作可观察对象

// 创建subject
var subject = new Rx.Subject();

//为subject注册两个观察者observerA、observerB
subject.subscribe({
  next: (v) => console.log('observerA: ' + v)
});
subject.subscribe({
  next: (v) => console.log('observerB: ' + v)
});

//subject作为可观察对象,为两个观察者播数据;
//第一次播报,给A和B发送1;
//第二次播报,给A和B发送2
subject.next(1);
subject.next(2);

// observerA: 1;
// observerB: 1;
// observerA: 2;
// observerB:  2;

也可以这么写

// 创建subject
var subject = new Rx.Subject();

//定义两个观察者A和B
const observerA = {
	next: (v) => console.log('observerA: ' + v);
}
const observerB = {
	next: (v) => console.log('observerB: ' + v);
}
//为subject注册两个观察者observerA、observerB
subject.subscribe(observerA);
subject.subscribe(observerB);

//subject作为可观察对象,为两个观察者播数据;
//第一次播报,给A和B发送1;
//第二次播报,给A和B发送2
subject.next(1);
subject.next(2);

Subject作观察者

把subject当作观察者,那它也可以作观察者订阅observable。

observable.subscribe(subject);
var observable = Rx.Observable.from([1, 2, 3]);
var subject = new Rx.Subject();

//定义两个观察者A和B
const observerA = {
	next: (v) => console.log('observerA: ' + v);
}
const observerB = {
	next: (v) => console.log('observerB: ' + v);
}
//为subject注册两个观察者observerA、observerB
subject.subscribe(observerA);
subject.subscribe(observerB);

observable.subscribe(subject); // 你可以提供一个 Subject 进行订阅
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Silam Lin

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值