AngularJS中关于ng-class指令的几种实现方式详解

前言

开发中经常会遇到这样的需求,一个元素需要在不同的状态下呈现不同的样子,而在这所谓的的样子当然就是改变其css的属性,而实现动态的改变属性值,我们就需要实现动态的更换其class属性值。

在这给大家介绍三种方法来实现,大家可以根据自己的需求来选择方式,下面来看看。

第一种:通过数据的双向绑定(不推荐)

?
1
2
3
4
5
6
7
8
9
10
11
< div ng-controller = "firstController" >
   < div ng-class = "{{className}}" ></ div >
 
</ div >
< script >
   var app=angular.module("myModule",[])
    app.controller('firstController',function($scope){
      $scope.className='change';
 
    })
</ script >

网上各种不推荐,说实话,既然angularJS双向数据绑定这么吊,为什么不能通过这个来改变呢!查了下原由:“在controller涉及了classname在我看来是乎总是那么诡异,我希望的是controller是一个干净的纯javascript意义的object”,当然并没有明文固定不能够这么使用的,而且反而我觉得这样非常的方便,让html中元素想怎么变就怎么变!同理中的img元素中的src就不可以通过别的来改变,但是通过这种方式就是可以的!当然,这种方式也的确给人的感觉怪怪的,个人认为:可以不得已而为之~

第二种:通过对象数组

?
1
2
3
4
5
6
7
8
9
10
11
12
13
< div ng-controller = "firstController" >
 
  < div ng-class = "{true:'change1',false:'change2'}[className]" ></ div >
 
 
</ div >
< script >
   var app=angular.module("myModule",[])
    app.controller('firstController',function($scope){
      $scope.className=true;
 
    })
</ script >

实现很简单,就是当classNametrue的时候classchange1,相反则为change2

但是有一点不好的只能够让一个元素拥有两种状态,虽然这么说!基本也是满足所需了,我一般都用这个。简单、直观!

第三种:通过key/value

?
1
2
3
4
5
6
7
8
9
10
11
12
13
< div ng-controller = "firstController" >
 
   < div ng-class = "{'change1':select,'change2':choice,'change3':lala}" >
 
</ div >
< script >
   var app=angular.module("myModule",[])
    app.controller('firstController',function($scope){
      $scope.select=true;
      $scope.lala=true;
 
    })
</ script >

lalatrue的时候,class则为change3,个人认为这个是比较推荐的,可以弥补第二种方式的点点遗憾~

猜你喜欢

转载自blog.csdn.net/u013184759/article/details/55252760
今日推荐