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清除定時器遇到的坑,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
|
新聞熱點
疑難解答