如何用2个参数创建主题(rx.js)?

时间:2016-11-25 12:35:26

标签: angular typescript rxjs angular2-components subject

我正在使用subject作为angular2应用程序中组件的通信服务。

通话方式:

Copy / Paste | Copy node GUID 
to clipboard

服务:

this.notification.create('test');

被叫功能:

export class NotificationService {
  private static notificationSource = new Subject<any>()

  notiCreated$ = NotificationService.notificationSource.asObservable();

  create(message) {
    NotificationService.notificationSource.next(message);
  }
}

但我想通过2个参数。而且我遇到了错误。

我该怎么做?

1 个答案:

答案 0 :(得分:9)

由于next的api为next(value: T): void,因此只能使用一个参数。 参考:http://reactivex.io/rxjs/class/es6/Subscriber.js~Subscriber.html

作为一种解决方法,您可以将消息分组到对象中:

this.notification.create({message1:'test', message2:'test2'});
消费时,只需选择所需的信息:

 this.subscription = notification.notiCreated$.subscribe(
    data => {
       console.log(data.message1, data.message2);
       this.createNotification(data.message1, 'warning');
  });