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

相关内容

热门资讯

黑科技代打(aa poker辅... 《黑科技代打(aa poker辅助软件)wEpOke总是存在有挂!太夸张了原来是有挂(2022已更新...
黑科技辅助挂(Wepoke a... 1、黑科技辅助挂(Wepoke app)wpK真是真的是有挂!太夸张了一向真的有挂(2022已更新)...
黑科技教学(德扑之星数据)We... 1、黑科技教学(德扑之星数据)Wepoke往昔是有挂!太夸张了原先存在有挂(2021已更新)(哔哩哔...
黑科技真的(wpk专用)德州a... 1、黑科技真的(wpk专用)德州aapoker俱乐部真是存在有挂!太坑了原来有挂(2026已更新)(...
黑科技最新(德扑之星抽水)aa... 黑科技最新(德扑之星抽水)aapOKER确实有挂!太坑了原本真的有挂(2026已更新)(哔哩哔哩);...
黑科技规律(wepoke辅助挂... 黑科技规律(wepoke辅助挂)wePOke总是真的有挂!太坑了起初真的有挂(2026已更新)(哔哩...
黑科技好牌(wpk模拟器)德州... WePoker透视辅助工具核心要点解析‌,黑科技好牌(wpk模拟器)德州扑克微扑克固有是真的有挂!太...
黑科技讲解(wpk教程)轰趴大... 黑科技讲解(wpk教程)轰趴大菠萝确实真的有挂!太实锤了一贯是真的有挂(2022已更新)(哔哩哔哩)...
黑科技攻略(wpkplus)云... 黑科技攻略(wpkplus)云扑克cloudpoker原生是有挂!太坑了都是真的是有挂(2025已更...
黑科技能赢(德扑线上创建房间)... 1、黑科技能赢(德扑线上创建房间)轰趴大菠萝从前有挂!太嚣张了总是是真的有挂(2020已更新)(哔哩...