android计时器创建与销毁,Angular2:创建并销毁计时器

我正在尝试创建计时器,它将每5秒发送一次GET请求,我设法做到了,但我注意到如果我移动到不同的页面(路由)计时器仍在运行,所以我尝试添加ngOnDestroy,但我不知道没有“取消订阅”的方法

import {Component,OnInit,OnDestroy} from '@angular/core';

import {Observable} from 'rxjs/Rx';

@Component({

templateUrl: 'app/pages/CurrentRuns/currentruns.component.html'

})

export class CurrentRunsComponent implements OnInit,OnDestroy {

private timer;

ticks=0;

ngOnInit() {

this.timer = Observable.timer(2000,5000);

this.timer.subscribe(t => this.tickerFunc(t));

}

tickerFunc(tick){

console.log(this);

this.ticks = tick

}

ngOnDestroy(){

console.log("Destroy timer");

}

}

我正在使用angular2 RC7,“rxjs”:“5.0.0-beta.12”

订阅observable会返回订阅对象

import {Component,OnDestroy} from '@angular/core';

import { Observable,Subscription } from 'rxjs/Rx';

@Component({

templateUrl: 'app/pages/CurrentRuns/currentruns.component.html'

})

export class CurrentRunsComponent implements OnInit,OnDestroy {

ticks = 0;

private timer;

// Subscription object

private sub: Subscription;

ngOnInit() {

this.timer = Observable.timer(2000,5000);

// subscribing to a observable returns a subscription object

this.sub = this.timer.subscribe(t => this.tickerFunc(t));

}

tickerFunc(tick){

console.log(this);

this.ticks = tick

}

ngOnDestroy(){

console.log("Destroy timer");

// unsubscribe here

this.sub.unsubscribe();

}

}

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

小编个人微信号 jb51ccc

喜欢与人分享编程技术与工作经验,欢迎加入编程之家官方交流群!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值