關於AngularJS中的ng-class

    在前面Angularjs開發一些經驗總結中咱們說到在angular開發中angular controller never 包含DOM元素(html/css),在controller須要一個簡單的POJO(plain object javascript object),與view徹底的隔離(交互angularjs框架的職責。但在某些項目中看見controller涉及DOM的元素最多的是在controller scope上定義某變量,其值爲class name,形如: javascript

function ctr($scope){
   $scope.test =「classname」;
}
<div class=」{{test}}」></div>

     這種方式徹底沒錯,是angular提供的一種改變class的方式,可是在controller涉及了classname在我看來是乎老是那麼詭異,我但願的是controller是一個乾淨的純javascript意義的object。css

    在angular中爲咱們提供了3種方案處理class:
        1:scope變量綁定,如上例。(不推薦使用)
        2:字符串數組形式。
        3:對象key/value處理。html

    咱們繼續其餘兩種解決方案:
    1字符串數組形式是針對class簡單變化,具備排斥性的變化,true是什麼class,false是什麼class,其形如;java

function Ctr($scope) { 
    $scope.isActive = true;
}

<div ng-class="{true: 'active', false: 'inactive'}[isActive]">
</div>

    其結果是2中組合,isActive表達式爲true,則 active,負責inactive。angularjs

    2對象key/value處理主要針對複雜的class混合,其形如:數組

function Ctr($scope) { 

}
<div ng-class {'selected': isSelected, 'car': isCar}">
</div>

    當 isSelected = true 則增長selected class,
    當isCar=true,則增長car class,
    因此你結果多是4種組合。框架

    我的推薦用2,3兩種方式,不建議將class放入controller scope之上,scope須要保持純潔行,scope上的只能是數據和行爲。spa

相關文章
相關標籤/搜索