Angular 7 - Emitter 和 Poller(被调用两次)
创始人
2024-10-16 14:30:10
0

在Angular 7中,你可以使用RxJS库来实现Emitter和Poller的功能。下面是一个示例代码:

import { Component, OnInit, OnDestroy } from '@angular/core';
import { Observable, Subscription, interval } from 'rxjs';
import { takeWhile } from 'rxjs/operators';

@Component({
  selector: 'app-emitter-poller',
  template: `
    

Angular 7 - Emitter and Poller

`, }) export class EmitterPollerComponent implements OnInit, OnDestroy { private emitterSubscription: Subscription; private pollerSubscription: Subscription; private emitterInterval = 1000; private pollerInterval = 2000; private isEmitterRunning = false; private isPollerRunning = false; ngOnInit() {} ngOnDestroy() { this.stopEmitter(); this.stopPoller(); } startEmitter() { if (!this.isEmitterRunning) { this.isEmitterRunning = true; this.emitterSubscription = interval(this.emitterInterval).subscribe(() => { this.emitData(); }); } } stopEmitter() { if (this.isEmitterRunning) { this.isEmitterRunning = false; this.emitterSubscription.unsubscribe(); } } startPoller() { if (!this.isPollerRunning) { this.isPollerRunning = true; this.pollerSubscription = interval(this.pollerInterval) .pipe(takeWhile(() => this.isPollerRunning)) .subscribe(() => { this.pollData(); }); } } stopPoller() { if (this.isPollerRunning) { this.isPollerRunning = false; this.pollerSubscription.unsubscribe(); } } emitData() { // 发送数据的逻辑 console.log('Data emitted'); } pollData() { // 轮询数据的逻辑 console.log('Data polled'); } }

在上面的示例中,我们使用了RxJS的interval函数来定时发送数据和轮询数据。startEmitter和startPoller方法分别启动了Emitter和Poller的功能,stopEmitter和stopPoller方法停止了它们。emitData和pollData方法是具体的数据发送和轮询逻辑,你可以根据自己的需求进行定制。

请注意,在组件销毁时,我们调用了ngOnDestroy方法来停止Emitter和Poller,这是为了避免内存泄漏。

相关内容

热门资讯

第4分钟安装!微乐小程序免费黑... 第4分钟安装!微乐小程序免费黑科技,微信微乐辅助(开挂)其实真的有挂(2026)1、每一步都需要思考...
透视中牌率!微乐小程序免费黑科... 透视中牌率!微乐小程序免费黑科技,小程序微乐陕西挖坑辅助器(透视)本来存在有挂(哔哩哔哩)1、小程序...
第六分钟安装!微乐小程序黑科技... 第六分钟安装!微乐小程序黑科技,收i就微乐小程序游戏破解器(开挂)果然存在有挂(2026)一、微乐小...
软件辅助挂!微乐小程序黑科技,... 软件辅助挂!微乐小程序黑科技,微信小程序微乐安徽辅助器(透视)果然是有挂(哔哩哔哩)一、微信小程序微...
三分钟安装!微乐小程序黑科技,... 三分钟安装!微乐小程序黑科技,微乐自建房脚本如何下载(开挂)原来是有挂(2026)微乐小程序黑科技是...
2026版总结!微乐小程序免费... 2026版总结!微乐小程序免费黑科技,微乐小程序辅助(透视)果然是真的挂(哔哩哔哩)进入游戏-大厅左...
八分钟下载!微乐小程序黑科技,... 八分钟下载!微乐小程序黑科技,微乐贵阳捉鸡麻将挂软件(开挂)好像真的是有挂(2026)1、打开软件启...
明白辅助挂!微乐小程序免费黑科... 明白辅助挂!微乐小程序免费黑科技,微信小程序微乐破解器(透视)确实真的是有挂(哔哩哔哩);1、游戏颠...
第五分钟安装!微乐小程序黑科技... 第五分钟安装!微乐小程序黑科技,微乐自建房安装挂(开挂)切实真的有挂(2026)1、上手简单,内置详...
据了解!微乐小程序黑科技,微乐... 据了解!微乐小程序黑科技,微乐家乡破解版(透视)竟然有挂(哔哩哔哩)1、上手简单,内置详细流程视频教...