【问题标题】:RxJS: unsubscribe from nested subscribeRxJS:取消订阅嵌套订阅
【发布时间】:2020-12-29 18:42:25
【问题描述】:

我使用 SockJS 和 StompJS,当我在浏览器中打开我的应用程序时,有时它会在连接到 websocket 之前尝试订阅一些主题。我希望主题订阅等到应用连接到 websocket。

export class SocksService {
...

public subscribe<T>(destination: string, callback?: (body: T) => void, headers?: object): Observable<Subscription> {
const subscription = new Subject<Subscription>();
headers = headers || {};

this.status.pipe(
  first(status => status === ConnectionStatus.CONNECTED)
).subscribe((status: ConnectionStatus) => {
  subscription.next(this.stompClient.subscribe(destination, (message: Message) => {
    if (callback) {
      callback(JSON.parse(message.body) as T);
    }
  }, headers));
});

return subscription.asObservable();
  }

...
}

这就是我实现这段代码的原因,我这样称呼它:

this.socksService.subscribe<User>('/topic/user', (user: User) => {
  console.log('user received', user);
}).subscribe(subscription => this.userSubscription = subscription);

所以我只在连接状态为connected时才订阅主题,并且只会在客户端第一次连接成功时调用。

我想稍后退订该主题,所以我需要内部订阅返回的Subscription 对象,我还需要来自内部订阅的消息。

我实现的效果很好,但我认为必须有更好的方法来做到这一点。

(我尝试了 rx-stomp,但它有很多错误。)

【问题讨论】:

    标签: javascript websocket rxjs stomp


    【解决方案1】:

    您说您尝试过 rx-stomp,但您是否尝试过 Angular2+ 版本的 rx-stomp,称为 ng2-stompjs?它将关键类公开为 Angular 可注入服务。

    在 rx-stomp 下查看它的提及,这里: https://github.com/stomp-js/ng2-stompjs#documentation

    ...它的实现(Angular 7)通过一个很好的一步一步,在这里: https://stomp-js.github.io/guide/ng2-stompjs/ng2-stomp-with-angular7.html#receiving-messages

    例如:

    this.rxStompService.watch('/topic/demo').subscribe((message: Message) => {
          this.receivedMessages.push(message.body);
        });
    

    【讨论】:

    • 是的,这就是我尝试过的库。无法配置它的某些部分,并且当它断开连接时,尽管一切正常,但它无法立即重新连接。所以我改用 SockJS 和旧版 StompJS,一切正常。
    猜你喜欢
    • 2021-11-18
    • 1970-01-01
    • 2017-08-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-03-26
    • 2020-10-28
    • 2023-03-23
    相关资源
    最近更新 更多