angularJs-髒檢查

來源:互聯網
上載者:User

標籤:control   固定   推薦   copy   保留   改變   屬性   handle   strong   

來自:http://www.cnblogs.com/liuyanan/p/4935652.html

 

scope是一個指嚮應用model的object,也是運算式的執行內容。 scope被放置在一個類似應用的DOM結構的階層中

angular中變數是雙向繫結的 ,那麼怎麼知道一個變數是否是變化了呢?

1、只能通過固定的介面才能改變變數的值,比如說只能通過set()設定變數的值,set被調用的時候比較一下就知道了。這種方法的缺點是寫法比較繁瑣。2、髒檢查,將原對象複製一份快照,在某個時間,比較現在對象與快照的值,如果不一樣就表明發生了變化,這個策略要保留兩份變數,而且要遍曆對象,比較每個屬性,這樣會有一定的效能問題 angular使用的就是髒檢查:1、不會髒檢查所有的對象。當對象被綁定到html中後,這個對象才會添加為檢查對象(watcher)2、不會髒檢查所有的屬性。同樣當屬性被綁定後,這個屬性才會被列為檢查的屬性在angular程式初始化時,會將綁定的對象的屬性添加為監聽對象(watcher),也就是說一個對象綁定了N個屬性,就會添加N個watcher。angular什麼時候去髒檢查呢?angular所有系統的方法中都會觸發比較事件,比如:controller初始化的時候,所有以ng-開頭的事件被執行後,都會觸發髒檢查必要的時候我們要手動的觸發髒檢查:$apply僅僅只是進入angular context,然後通過$digest觸發髒檢查$apply如果不給參數的話,會檢查該$scope裡的所有監聽的屬性,所以推薦給上參數。 $apply怎麼使用:
<script>
var firstController=function($scope){
  $scope.date = new Date();
  setInterval(function(){
    $scope.$apply(function(){     $scope.date = new Date();     //在這裡去手動觸發髒檢查
    })  },1000)

}
</script>

<div ng-app>
  <div ng-controller = "firstController">
    {{date}}
  </div>
</div>

$apply實現髒檢查實際上是通過$digest實現的,但是我們不能直接使用$digest來觸發,原因是在$apply 與$digest之間還有一層很重要的$evel判斷。如果中間有錯誤$evel將會把錯誤交送到$exceptionHandler進行處理

angularJs-髒檢查

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.