Angular ng-class詳解及實(shí)例代碼
在前面Angularjs開發(fā)一些經(jīng)驗(yàn)總結(jié)中我們說到在angular開發(fā)中angular controller never 包含DOM元素(html/css),在controller需要一個(gè)簡單的POJO(plain object javascript object),與view完全的隔離(交互angularjs框架的職責(zé)。但在某些項(xiàng)目中看見controller涉及DOM的元素最多的是在controller scope上定義某變量,其值為class name,形如:
function ctr($scope){ $scope.test =“classname”; } <div class=”{{test}}”></div>
這種方式完全沒錯(cuò),是angular提供的一種改變class的方式,但是在controller涉及了classname在我看來是乎總是那么詭異,我希望的是controller是一個(gè)干凈的純javascript意義的object。
在angular中為我們提供了3種方案處理class:
1:scope變量綁定,如上例。(不推薦使用)
2:字符串?dāng)?shù)組形式。
3:對象key/value處理。
我們繼續(xù)其他兩種解決方案:
1字符串?dāng)?shù)組形式是針對class簡單變化,具有排斥性的變化,true是什么class,false是什么class,其形如;
function Ctr($scope) { $scope.isActive = true; } <div ng-class="{true: 'active', false: 'inactive'}[isActive]"> </div>
其結(jié)果是2中組合,isActive表達(dá)式為true,則 active,負(fù)責(zé)inactive。
2對象key/value處理主要針對復(fù)雜的class混合,其形如:
function Ctr($scope) { } <div ng-class {'selected': isSelected, 'car': isCar}"> </div>
當(dāng) isSelected = true 則增加selected class,
當(dāng)isCar=true,則增加car class,
所以你結(jié)果可能是4種組合。
個(gè)人推薦用2,3兩種方式,不建議將class放入controller scope之上,scope需要保持純潔行,scope上的只能是數(shù)據(jù)和行為。
以上就是對Angular ng-class詳解,后續(xù)繼續(xù)補(bǔ)充相關(guān)資料,謝謝大家對本站的支持!
相關(guān)文章
AngularJS實(shí)現(xiàn)自定義指令與控制器數(shù)據(jù)交互的方法示例
這篇文章主要介紹了AngularJS實(shí)現(xiàn)自定義指令與控制器數(shù)據(jù)交互的方法,結(jié)合具體實(shí)例形式分析了AngularJS自定義指令的實(shí)現(xiàn)以及與控制器數(shù)據(jù)交互的操作技巧,需要的朋友可以參考下2017-06-06詳解Angular的數(shù)據(jù)顯示優(yōu)化處理
本文主要對Angular的數(shù)據(jù)顯示優(yōu)化處理進(jìn)行詳細(xì)介紹,具有一定的參考價(jià)值,下面跟著小編一起來看下吧2016-12-12AngularJS模塊學(xué)習(xí)之Anchor Scroll
這篇文章主要介紹了AngularJS模塊學(xué)習(xí)之Anchor Scroll 的相關(guān)資料,需要的朋友可以參考下2016-01-01解決Angularjs異步操作后臺(tái)請求用$q.all排列先后順序問題
解決Angularjs異步操作后臺(tái)請求用$q.all排列先后順序問題,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-11-11詳解什么是@ngrx/store開發(fā)包中的MemoizedSelector
這篇文章主要為大家介紹了@ngrx/store開發(fā)包中的MemoizedSelector使用分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07使用xampp將angular項(xiàng)目運(yùn)行在web服務(wù)器的教程
這篇文章主要介紹了使用xampp將angular項(xiàng)目運(yùn)行在web服務(wù)器,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09