您好,登錄后才能下訂單哦!
小編給大家分享一下angularJs中關于ng-class的使用方式有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
在開發中我們通常會遇到一種需求:一個元素在不同的狀態需要展現不同的樣子。
而在這所謂的樣子當然就是改變其css的屬性,而實現能動態的改變其屬性值,必然只能是更換其class屬性
這里有三種方法:
第一種:通過數據的雙向綁定(不推薦)
第二種:通過對象數組
第三種:通過key/value( 推薦 )
下面簡單說下這三種:
第一種:通過數據的雙向綁定
實現方式:
function changeClass(){ $scope.className = "change2"; } <div class="{{className}}"></div>
網上各種不推薦,說實話,既然angularJS雙向數據綁定這么吊,為什么不能通過這個來改變呢!查了下原由:“在controller涉及了classname在我看來是乎總是那么詭異,我希望的是controller是一個干凈的純javascript意義的object”,當然并沒有明文固定不能夠這么使用的,而且反而我覺得這樣非常的方便,讓html中元素想怎么變就怎么變!同理中的img元素中的src就不可以通過別的來改變,但是通過這種方式就是可以的!
當然,這種方式也的確給人的感覺怪怪的,個人認為:可以不得已而為之~
第二種:通過字符串數組的形式來改變
實現方式:
function changeClass(){ $scope.className = true/false; } <div ng-class="{true:'zhende',false:'jiade'}[className]"></div>
實現很簡單,就是當className為真的時候class為zhende,相反則為jiade。
但是有一點不好的只能夠讓一個元素擁有兩種狀態,雖然這么說!基本也是滿足所需了,我一般都用這個。簡單、直觀!
第三種:通過key/value的方式
實現方式:
function changeClass(){ $scope.lala = true; } <div ng-class="{'selectClass':select,'choiceClass':choice,'haha':lala}"></div>
當lala為true的時候,class則為haha,個人認為這個是比較推薦的,可以彌補第二種方式的點點遺憾~
以上是“angularJs中關于ng-class的使用方式有哪些”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。