Angular可以启动计时器但无法停止它
创始人
2024-10-27 20:01:32
0

可以使用RxJS中的Interval Observable来代替原生的setInterval函数,并使用takeUntil操作符来停止计时器。 示例代码如下:

import { Component, OnDestroy } from '@angular/core'; import { interval, Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators';

@Component({ selector: 'app-counter', template: {{ counter }} }) export class CounterComponent implements OnDestroy { counter = 0; private interval$ = interval(1000); private stop$ = new Subject();

start() { this.interval$ .pipe(takeUntil(this.stop$)) .subscribe(() => { this.counter++; }); }

stop() { this.stop$.next(); this.stop$.complete(); this.counter = 0; }

ngOnDestroy() { this.stop$.next(); this.stop$.complete(); } }

在上面的代码中,我们定义了一个Interval Observable来代替setInterval函数,并在start函数中使用takeUntil操作符来停止计时器。我们还定义了一个stop$Subject来控制计时器应停止,并在stop函数中调用了next和complete方法以确保计时器被完全停止。我们也实现了ngOnDestroy接口以在组件销毁时停止计时器并清零计数器。

相关内容

热门资讯

第8分钟辅助!wepoker辅... 第8分钟辅助!wepoker辅助器是真的吗,wepoker透视脚本免费app,指引教程(真是有挂)1...
8分钟辅助!wepoker辅助... 8分钟辅助!wepoker辅助真的假的,wpk真吗,阶段教程(有挂方针)8分钟辅助!wepoker辅...
第2分钟辅助!德普之星透视辅助... 第2分钟辅助!德普之星透视辅助软件,wpk官网下载链接,资料教程(有挂秘籍)1、点击下载安装,德普之...
第一分钟辅助!拱趴大菠萝开挂方... 第一分钟辅助!拱趴大菠萝开挂方法,竞技联盟透视插件,方针教程(存在有挂)拱趴大菠萝开挂方法辅助器是一...
第一分钟辅助!德州透视插件,h... 第一分钟辅助!德州透视插件,hardrock作弊,总结教程(有挂方针)德州透视插件是不是有人用挂微扑...
四分钟辅助!wepoker看底... 四分钟辅助!wepoker看底牌,wejoker透视方法,指南教程(有挂辅助)1、wejoker透视...
四分钟辅助!wpk辅助哪里买,... 四分钟辅助!wpk辅助哪里买,如何下载德普之星辅助软件,指引教程(发现有挂)1、游戏颠覆性的策略玩法...
七分钟辅助!大菠萝免费辅助器,... 七分钟辅助!大菠萝免费辅助器,wepoker轻量版有透视吗,策略教程(确实有挂)1、打开软件启动之后...
六分钟辅助!哈糖大菠萝挂,we... 六分钟辅助!哈糖大菠萝挂,wepokerplus辅助,阶段教程(存在有挂)1、金币登录送、破产送、升...
第八分钟辅助!cloudpok... 第八分钟辅助!cloudpoker怎么开挂,哈糖大菠萝可以开挂吗,秘籍教程(有挂规律)所有人都在同一...