亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

angularjs定時任務的設置與清除示例

發布時間:2020-10-09 04:15:27 來源:腳本之家 閱讀:225 作者:heartbeaty 欄目:web開發

人們似乎常常將AngularJS中的$timeOut()  $interval()函數看做是一個內置的、無須在意的函數。但是,如果你忘記了$timeOut()$interval()的回調函數將會造成非常不好的影響,你可能會因此遇到代碼莫名其妙的出現問題,或者無端拋出一個錯誤甚至是一遍一遍的重復對的你的服務器進行$http請求這些詭異的情形。管理好你的$timeOut/$interval定時器的小技巧就是在$destory事件中將它們取消。

和JavaScript中原生的setTimeout()以及setInterval()函數不同,AngularJS中的$timeOut()函數會返回一個promise。和其他的promise一樣,你可以綁定$timeOut的resolved和rejected時間。然而更重要的是,你可以通過將這個promise傳遞給$timeOut.cancel()方法來取消掉潛在的定時器。

設置定時任務,給定時任務起一個名字time_upd,為的是方便清理的時候直接調用名稱。

var timeout_upd = $interval($scope.upd_data ,6000); 

注意:設置的時候$interval(fn ,time);第一個參數fn 不能寫“()”,只能寫$scope.方法名稱。第二個參數是定時執行的時間間隔,單位為毫秒。

清除定時任務,AngularJS將會在scope中觸發$destory事件。這讓我們可以有機會來cancel任何潛在的定時器。

$scope.$on('$destroy',function(){ 
    $interval.cancel(timeout_upd); 
  }) 

我的頁面是這種格式的,如下圖所示。angularjs在“實時數據監測”這個模塊設置了一個定時任務,當我點擊菜單欄到別的頁面時,默認的這個定時任務還在執行,占用很多資源。所以必須得清除這個定時任務,原生的清除window.clearInterval(timeout_upd);是不管用的,必須用angularjs自帶的清除方法,如上代碼所示。

angularjs定時任務的設置與清除示例

注意:angularjs中設置了定時任務之后,必須清除定時任務,不然angularjs會在離開這個controller后,仍然會執行這個定時任務。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

龙海市| 鄂托克前旗| 城市| 班戈县| 疏附县| 银川市| 石家庄市| 辽阳市| 英超| 大埔县| 武乡县| 澄江县| 平潭县| 津南区| 广灵县| 靖远县| 郴州市| 申扎县| 铁岭县| 南丹县| 齐齐哈尔市| 景谷| 枣阳市| 峨边| 山西省| 邓州市| 高淳县| 修水县| 蚌埠市| 台州市| 桦甸市| 沙坪坝区| 古蔺县| 丘北县| 绥江县| 无棣县| 闵行区| 麻阳| 修文县| 从江县| 延津县|