您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關如何解決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()
,
必須一一對應,不一致是不會清除掉的。
感謝各位的閱讀!關于“如何解決AngualrJs清除定時器遇到的坑”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。