【问题标题】:Websocket in Angular 4 and RxJS confusionAngular 4 中的 Websocket 和 RxJS 混淆
【发布时间】:2018-02-08 14:51:23
【问题描述】:

我正在尝试使用 websockets 和 Angular 4 学习 RxJS,并找到了一个很好的例子 here。我希望有人可以帮助解释该示例,因为有些事情令人困惑。

他们创建了 2 个 Angular 服务,即 Websocket 服务:

import { Injectable } from '@angular/core';
import * as Rx from 'rxjs/Rx';

@Injectable()
export class WebsocketService {
  constructor() { }

  private subject: Rx.Subject<MessageEvent>;

  public connect(url): Rx.Subject<MessageEvent> {
    if (!this.subject) {
      this.subject = this.create(url);
      console.log("Successfully connected: " + url);
    } 
    return this.subject;
  }

  private create(url): Rx.Subject<MessageEvent> {
    let ws = new WebSocket(url);

    let observable = Rx.Observable.create(
    (obs: Rx.Observer<MessageEvent>) => {
        ws.onmessage = obs.next.bind(obs);
        ws.onerror = obs.error.bind(obs);
        ws.onclose = obs.complete.bind(obs);
        return ws.close.bind(ws);
    })
let observer = {
        next: (data: Object) => {
            if (ws.readyState === WebSocket.OPEN) {
                ws.send(JSON.stringify(data));
            }
        }
    }
    return Rx.Subject.create(observer, observable);
  }

}

和聊天服务:

import { Injectable } from '@angular/core';
import { Observable, Subject } from 'rxjs/Rx';
import { WebsocketService } from './websocket.service';

const CHAT_URL = 'ws://echo.websocket.org/';

export interface Message {
    author: string,
    message: string
}

@Injectable()
export class ChatService {
    public messages: Subject<Message>;

    constructor(wsService: WebsocketService) {
        this.messages = <Subject<Message>>wsService
            .connect(CHAT_URL)
            .map((response: MessageEvent): Message => {
                let data = JSON.parse(response.data);
                return {
                    author: data.author,
                    message: data.message
                }
            });
    }
}

我对此有很多疑问:

  1. 为什么需要创建 2 个服务?主题不能成为观察者和可观察的(因此它可以直接转发消息而无需第二个聊天服务)?解决创建 2 个服务的问题是什么?
  2. 在Websocket服务中,为什么.create函数调用的最后一行返回ws.close.bind(ws)?那有什么作用?
  3. 如何处理 websocket 的断开连接?有没有办法让它重新连接?
  4. 服务应该如何关闭/处理 websocket?

【问题讨论】:

  • 发布后几秒钟内被否决?我希望一个解释即将到来。
  • 如果您心中有所有这些问题,是什么让您认为这个例子是一个好例子? :-)。对我来说,基本的、简单的方法总是更好:stackoverflow.com/questions/37025837/…(两个答案都简单而有用)。顺便说一句,投反对票的原因显然是这个问题太宽泛了,因为它被标记为这样,因为你问了 4 合 1 的问题,你基本上期望一个非常广泛的问题,而不是一个具体的答案(我也讨厌无理的投反对票)。
  • websocket+RxJS+ng2 的文档非常少,所以我一直在看示例。这是我能找到的最简单的例子......所以我试图理解它。我研究过个别作品,但有些还没有意义

标签: angular typescript websocket rxjs


【解决方案1】:
  1. 可重用性
  2. 因此您可以取消订阅 observable 从而关闭连接
  3. 在您给出的示例中,它可能类似于(当您有一个 chatService 实例时)

    let sub = chatService.messages.subscribe(()=>{ 
    // do your stuff 
    });
    
    // some where in your code
    sub.unsubscribe() // this will close the connection
    
  4. 已在 3 中回答

【讨论】:

  • 您能否详细说明答案#2 - 为什么返回关闭的结果只会在取消订阅时关闭套接字?函数返回时关闭不会立即运行吗?
  • Bind 返回关闭函数,其中 ws 为 'this'。它不会运行它。取消订阅将运行返回的函数,即close()
猜你喜欢
  • 2018-02-01
  • 1970-01-01
  • 2018-04-17
  • 2013-09-09
  • 2017-10-19
  • 1970-01-01
  • 1970-01-01
  • 2019-05-31
  • 1970-01-01
相关资源
最近更新 更多