RxJS - 多播操作符 multicast



多播操作符与其他订阅者共享创建的单个订阅。multicast 采用的参数是主题或返回 ConnectableObservable 的工厂方法,该 ConnectableObservable 必须具有 connect() 方法。要订阅,必须调用 connect() 方法。

语法

multicast(subjectOrSubjectFactory: Subject): OperatorFunction

参数

subjectOrSubjectFactory:传递给 multicast 的参数是主题或返回主题的工厂方法。

在我们了解 multicast() 操作符的工作原理之前,让我们先了解一下 multicast() 操作符如何提供帮助。

考虑以下具有订阅的简单可观察对象的示例 -

示例

import { Observable } from 'rxjs';

var observable = new Observable(function subscribe(subscriber) {
   try {
      subscriber.next(Math.random());
   } catch (e) {
      subscriber.error(e);
   }
});
const subscribe_one = observable.subscribe(val => console.log(
   "Value from Sub1 = "+val)
);
const subscribe_two = observable.subscribe(val => console.log(
   "Value from Sub2 = "+val)
);

输出

multicast Operator

如果您看到输出,Sub1 和 Sub2 的值不同。这是因为当调用订阅者时,可观察对象重新启动并提供可用的新值。但是,我们需要让被调用的订阅者具有相同的值。

在这里,我们有 multicast() 操作符来帮助我们完成它。

示例

import { Observable,Subject } from 'rxjs';
import { take, multicast, mapTo } from 'rxjs/operators';

var observable = new Observable(function subscribe(subscriber) {
   try {
      subscriber.next(Math.random());
   } catch (e) {
      subscriber.error(e);
   }
});
const multi_op = observable.pipe(multicast(() => new Subject()));
const subscribe_one = multi_op.subscribe(
   x => console.log("Value from Sub1 = "+x)
);
const subscribe_two = multi_op.subscribe(
   x => console.log("Value from Sub2 = "+x)
);
multi_op.connect();

如果您现在看到被调用的订阅者之间共享相同的值。

输出

multicast Operator
广告