javascript - How do I bind this scope variable to a ng-class attribute? - Stack Overflow

This seems like it should be fairly straightforward, however I'm absolutely out of options In my v

This seems like it should be fairly straightforward, however I'm absolutely out of options

In my view I have:

<div>{{selectedTheme.theme}}</div>
<ion-nav-view ng-class="selectedTheme.theme" name="menuContent"></ion-nav-view>

where the first div outputs the class as expected. However, I cannot get the class to get inserted into the ion-nav-view element!

The resulting mark-up is as follows:

<div class="ng-binding">Dark</div>
<ion-nav-view ng-class="selectedTheme.theme" name="menuContent" class="view-container" nav-view-transition="ios" nav-view-direction="none" nav-swipe="">></ion-nav-view>

Any input at all would be immense!

PS: In addition, setting it simply with class works fine.

This seems like it should be fairly straightforward, however I'm absolutely out of options

In my view I have:

<div>{{selectedTheme.theme}}</div>
<ion-nav-view ng-class="selectedTheme.theme" name="menuContent"></ion-nav-view>

where the first div outputs the class as expected. However, I cannot get the class to get inserted into the ion-nav-view element!

The resulting mark-up is as follows:

<div class="ng-binding">Dark</div>
<ion-nav-view ng-class="selectedTheme.theme" name="menuContent" class="view-container" nav-view-transition="ios" nav-view-direction="none" nav-swipe="">></ion-nav-view>

Any input at all would be immense!

PS: In addition, setting it simply with class works fine.

Share Improve this question asked Mar 14, 2015 at 23:45 Louis93Louis93 3,9219 gold badges53 silver badges94 bronze badges 3
  • I say you should go for a directive here and use element.addClass(). You should take a look at this question too – Dan Mindru Commented Mar 14, 2015 at 23:55
  • @JamesP, that is just not correct. ng-class accepts an expression that if evaluated to string of space-delimited class names or an array, uses these values as is. Only, when the expression is an object, the property is used as a class if it has a truthy value – New Dev Commented Mar 15, 2015 at 0:31
  • 1 if you just want the name of the class add {{}} and your good, Like : ng-class="{{selectedTheme.theme}}" – Neta Meta Commented Mar 15, 2015 at 0:46
Add a ment  | 

1 Answer 1

Reset to default 3

In Angular ng-classuses an expression or just a plain old string. You can do things like:

  1. Add/Remove classes based on Angular variables
  2. Add/Remove classes based on evaluated expressions
  3. Bind single or multiple classes based on dynamic data

You can just add an Angular variable to ng-class and that is the class that will be used for that element. So in your case, if selectedTheme.theme yields the exact class name you wish to use, then it should work fine.

<ion-nav-view ng-class="varHoldingClassName" name="menuContent"></ion-nav-view>

So here's a full example in action:

var myApp = angular.module('myApp',[]);

function MyCtrl($scope) {
    $scope.name = 'Angular!';
    $scope.selectedTheme = {
         'coalTheme': 'textColor'
    };
}
.textColor{
    color: red;  
}
<script src="https://ajax.googleapis./ajax/libs/angularjs/1.2.23/angular.min.js"></script>

<div ng-app="myApp">
<div ng-controller="MyCtrl">
    <div ng-class="selectedTheme.coalTheme">Hello, {{name}}!</div>
</div>
</div>

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1745597894a4635224.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信