这次给大家带来用angualrjs使用定时器,用angualrjs使用定时器的注意事项有哪些,下面就是实战案例,一起来看一下。
angualrjs清除定时器爬坑之路:
今天发现一个奇怪问题,放在自定义指令里边的定时器竟然在页面跳转之后,在另一个页面这个循环定时器还在执行,这肯定是不行的,会影响系统的性能。
我在angular里边用原生的方法window.onunload方法竟然不管用,所以只好用angular自己的方法$destroy,这页面跳转,dom结构发生变化是都能清除定时器
var timer = setinterval(function(){
$scope.$apply(function(){
//这里是想要定时刷新的逻辑
});
},3000);
$scope.$on('$destroy',function(){
if (timer) {
clearinterval(timer);
timer = null;
}
});
这里说一下,因为我用的是javascript中原生的settimeout()以及setinterval()函数,所以清除时对应是cleartimeout()和clearinterval(),angular定时器是$timeout和$interval,所以清除对应是$timeout.cancel()和$interval.cancel(),
必须一一对应,不一致是不会清除掉的。
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
js实现去重的随机数生成
exports与module.exports使用方法
以上就是用angualrjs使用定时器的详细内容。