内容字号:默认大号超大号

段落设置:段首缩进取消段首缩进

字体设置:切换到微软雅黑切换到宋体

angualrJs清除定时器详解

2017-10-12 17:03 出处:清屏网 人气: 评论(0

今天发现一个奇怪问题,放在自定义指令里边的定时器竟然在页面跳转之后,在另一个页面这个循环定时器还在执行,这肯定是不行的,会影响系统的性能。

我在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

相关文章

发表评论愿您的每句评论,都能给大家的生活添色彩,带来共鸣,带来思索,带来快乐。

CopyRight © 2015-2016 QingPingShan.com , All Rights Reserved.

清屏网 版权所有 豫ICP备15026204号