Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

AngularJS set initial active class

I'm using Bootstrap tabs with an Angular ng-repeat.

The problem I'm running into is that the first li and the first div.tab-pane each need an active class. Bootstrap takes care of that after a tab is clicked but, as you can see, not on load.

My question is, how can I set an active class on the first li and div.tab-pane?

Demo:

http://jsfiddle.net/FQgHx/

like image 645
Ryan Avatar asked May 30 '13 14:05

Ryan


1 Answers

All you have to do is put an ng-class directive on the tab and tab pane that you would like active initially. You can change the expression from $index == 0 in the ng-class directive to whatever you would like. This could use a function or variable in your scope.

Here is a JS Fiddle showing how to do this: http://jsfiddle.net/digitalzebra/qqPZd/

And here is the final code... notice the ng-class directives:

<div ng-app>
    <div ng-init="names = [{name:'one'}, {name:'two'}, {name:'three'}, {name:'four'}, {name:'five'}]">
    <ul class="nav nav-tabs">
    <li ng-repeat="name in names" ng-class="{active: $index == 0}">
      <a href="#tab{{$index + 1}}" data-toggle="tab">Week {{acute.Week}}</a>
    </li>
  </ul>
  <div class="tab-content">
    <div class="tab-pane fade in" id="tab{{$index + 1}}" ng-repeat="name in names" ng-class="{active: $index == 0}">
      <p>{{$index + 1}}</p>
    </div>
  </div>
</div>
</div>
like image 62
Polaris878 Avatar answered Sep 27 '22 21:09

Polaris878