周昌贡,后海小混蛋,珊瑚树家庭专家
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()
,
必须一一对应,不一致是不会清除掉的。
总结
以上所述是小编给大家介绍的angualrjs清除定时器遇到的坑,希望对大家有所帮助
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
Angular8引入百度Echarts进行图表分析的实现代码
解决Angularjs异步操作后台请求用$q.all排列先后顺序问题
angular inputNumber指令输入框只能输入数字的实现
网友评论