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接口以在组件销毁时停止计时器并清零计数器。

相关内容

热门资讯

一分钟辅助!wepoker辅助... 一分钟辅助!wepoker辅助器官方,hhpoker透视工具,绝活教程(果真有挂)1、wepoker...
第八分钟辅助!wpk系统是否存... 第八分钟辅助!wpk系统是否存在作弊行为,hhpkoer辅助器视频,手册教程(有挂猫腻)暗藏猫腻,小...
第四分钟辅助!哈糖大菠萝怎么挂... 第四分钟辅助!哈糖大菠萝怎么挂,wepoker透视功能下载,窍要教程(竟然有挂)在进入wepoker...
第5分钟辅助!epoker透视... 第5分钟辅助!epoker透视,德州局透视脚本下载安装最新版本,机巧教程(真实有挂)1、用户打开应用...
第九分钟辅助!aapoker透... 第九分钟辅助!aapoker透视怎么用,hhpoker辅助器视频,要领教程(有挂神器)1、用户打开应...
9分钟辅助!hhpoker透视... 9分钟辅助!hhpoker透视脚本,wepoker破解游戏盒子,练习教程(有挂技巧)1、金币登录送、...
7分钟辅助!wepoker辅助... 7分钟辅助!wepoker辅助分析器,菠萝辅助器免费版的特点,绝活教程(果真有挂)1)菠萝辅助器免费...
一分钟辅助!aapoker怎么... 一分钟辅助!aapoker怎么开辅助器,xpoker辅助控制,机巧教程(有挂细节)1、aapoker...
第四分钟辅助!we-poker... 第四分钟辅助!we-poker靠谱吗,wpk辅助是什么,教材教程(了解有挂)亲,关键说明,wpk辅助...
九分钟辅助!德州透视竞技联盟,... 九分钟辅助!德州透视竞技联盟,wepoker免费脚本咨询,窍门教程(发现有挂)1、超多福利:超高返利...