最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
AngualrJs清除定时器遇到的坑
时间:2017-10-19 编辑:猪哥 来源:一聚教程网
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()
,
必须一一对应,不一致是不会清除掉的。
相关文章
- 再谈Angular4 脏值检测(性能优化) 04-29
- angular中不同的组件间传值与通信的方法 11-29
- 初学者AngularJS的环境搭建过程 11-20
- angular4中关于表单的校验示例 10-27
- AngularJS 中的数据源的循环输出 10-13
- Angular实现预加载延迟模块的示例 10-13