細說Angular ng-class


       在前面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上的只能是數據和行為。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM