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

相关内容

热门资讯

透视工具!wpk ai机器人,... 透视工具!wpk ai机器人,(Wpk)真是真的有挂,黑科技小程序(有挂秘籍)-哔哩哔哩1、起透看视...
黑科技透视!(WePoKe)固... 黑科技透视!(WePoKe)固有真的是有挂,(wepoke)原来存在有挂,黑科技教学(有挂教程)-哔...
4分钟黑科技!德扑ai智能系统... 4分钟黑科技!德扑ai智能系统,(德扑)本然有挂,细节揭秘(有挂解密)-哔哩哔哩;运德扑ai智能系统...
透视教程!wpk透明挂,(Wp... 透视教程!wpk透明挂,(Wpk)原生真的有挂,黑科技新版(有挂工具)-哔哩哔哩;1、透视教程!wp...
透视ai(aapokER)透视... 透视ai(aapokER)透视辅助软件(透视)真是存在有挂(今日头条)-哔哩哔哩是一种具有地方特色的...
黑科技ai!(WePoKe)原... 黑科技ai!(WePoKe)原本存在有挂,(wepOke)原来真的有挂,黑科技最新款(有挂细节)-哔...
黑科技有挂!(WePoKe)最... 黑科技有挂!(WePoKe)最初是有挂,(wepokE)原来真的是有挂,黑科技稳赢(确实有挂)-哔哩...
1分钟辅助挂!微扑克ai辅助网... 1分钟辅助挂!微扑克ai辅助网页版,(微扑克)固有真的有挂,存在有挂(存在有挂)-哔哩哔哩1、这是跨...
3分钟黑科技!德扑ai软件,(... 3分钟黑科技!德扑ai软件,(德扑)竟然真的是有挂,大神讲解(有挂规律)-哔哩哔哩1、点击下载安装,...
透视黑科技(AAPoker)透... 透视黑科技(AAPoker)透视辅助插件(透视)都是是有挂(确实有挂)-哔哩哔哩;运辅助工具,进入游...