国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Angular ng-class詳解及實例代碼

2019-11-20 08:56:48
字體:
來源:轉載
供稿:網友

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

以上就是對Angular ng-class詳解,后續繼續補充相關資料,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 寿阳县| 类乌齐县| 龙山县| 大丰市| 喀喇沁旗| 菏泽市| 金昌市| 长岛县| 长兴县| 南汇区| 马边| 上林县| 钦州市| 伊吾县| 木里| 海阳市| 策勒县| 克什克腾旗| 遂溪县| 洛隆县| 乌兰察布市| 卢湾区| 许昌市| 龙泉市| 三明市| 阜城县| 辽阳市| 怀安县| 汾阳市| 德钦县| 仙游县| 缙云县| 金塔县| 台州市| 吉隆县| 澎湖县| 班玛县| 神农架林区| 吴江市| 海兴县| 元谋县|