Angular上服务器发送事件会造成多次调用
创始人
2024-10-29 10:00:58
0

为了解决此问题,您可以添加“take(1)”操作符来在第一次触发时停止订阅。这将确保触发事件仅会进行一次请求。以下是示例代码:

import {
  Injectable,
  NgZone
} from '@angular/core';
import { Observable } from 'rxjs/Observable';

@Injectable()
export class ServerSentEventsService {
  constructor(private ngZone: NgZone) {}

  getServerSentEvent(url: string): Observable {
    return Observable.create(observer => {
      const eventSource = new EventSource(url);

      eventSource.onmessage = event => {
        this.ngZone.run(() => observer.next(event));
      };

      eventSource.onerror = error => {
        this.ngZone.run(() => observer.error(error));
      };

      return () => {
        eventSource.close();
      };
    }).take(1);
  }
}

我们在Observable创建之后添加了“ .take(1) ”。这将关闭Observable,以便在第一次触发后不再调用它。

请注意,您需要从“Rxjs/Observable”导入“ take”操作符。

在这种情况下,我们没有必要再监听EventSource的“ onopen”事件,因为它实际上只会在首次订阅后发生。

相关内容

热门资讯

推荐十款!七彩云南麻将有没有挂... 推荐十款!七彩云南麻将有没有挂(透视)本来是有挂(2022已更新)(哔哩哔哩)1、七彩云南麻将有没有...
wepokeai机器人!用ai... wepokeai机器人!用ai外 挂打德州有用(辅助挂)wepOke(本来真的有挂);一、wepOk...
微扑克辅助软件!微扑克超级统计... 您好,微扑克这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中...
揭秘!广东雀神麻将怎么让系统发... 揭秘!广东雀神麻将怎么让系统发好牌(透视)果然是真的有挂(2020已更新)(哔哩哔哩)1、进入到广东...
wepoke辅助挂!wepok... wepoke辅助挂!wepoke好友助力(透视辅助)WePoKer(一般真的有挂);WePoKer软...
微扑克有辅助挂!微扑克俱乐部,... 微扑克有辅助挂!微扑克俱乐部,微扑克ai人工智能,wepoke教程(有挂黑科技)1、微扑克ai机器人...
玩家攻略推荐!闽游麻将(透视辅... 玩家攻略推荐!闽游麻将(透视辅助)原来存在有挂(2023已更新)(哔哩哔哩);1、闽游麻将ai辅助优...
软件教程!wopoker轻量版... 软件教程!wopoker轻量版外 挂(wepoke辅助技巧)wepoKE(果然真的有挂)关于wopo...
微扑克ai辅助工具!微扑克辅助... 微扑克ai辅助工具!微扑克辅助多少钱,微扑克ai操作,可靠技巧(有挂ai代打);人气非常高,ai更新...
玩家科普!吉祥麻将怎么让系统发... 玩家科普!吉祥麻将怎么让系统发好牌(透视辅助)竟然存在有挂(2026已更新)(哔哩哔哩)亲,关键说明...