在前面Angularjs開發一些經驗總結中我們說到在angular開發中angular controller never 包含DOM元素(html/css),在controller需要一個簡單的POJO(plain object javascript object),與view完全的隔離(互動angularjs框架的職責。但在某些專案中看見controller涉及DOM的元素最多的是在controller scope上定義某變數,其值為class name,形如:

function ctr($scope){

   $scope.test =“classname”;

}

<div class=”`test`”></div>

這種方式完全沒錯,是angular提供的一種改變class的方式,但是在controller涉及了classname在我看來是乎總是那麼詭異,我希望的是controller是一個乾淨的純javascript意義的object。

    在angular中為我們提供了3種方案處理class:

1:scope變數繫結,如上例。(不推薦使用)

2:字串陣列形式。

3:物件key/value處理。

我們繼續其他兩種解決方案:

     1字串陣列形式是針對class簡單變化,具有排斥性的變化,true是什麼class,false是什麼class,其形如;

function Ctr($scope) {

   $scope.isActive = true;

}

<div ng-class=”{true: `active`, false: `inactive`}[isActive]”>

</div>

     其結果是2中組合,isActive表示式為true,則 active,負責inactive。

      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上的只能是資料和行為。