Angular UI - 以编程方式设置活动选项卡

时间:2016-09-04 07:36:37

标签: angularjs angular-ui-bootstrap angular-ui angular-ui-tabset

我在这段代码中使用AngularUI:

<uib-tabset type="pills">
    <uib-tab heading="Tab 1">Tab 1 content</uib-tab>
    <uib-tab heading="Tab 2">Tab 2 content</uib-tab>
</uib-tabset>

我想以编程方式更改角度控制器代码中的当前活动标记。例如,选择标签&#34; 2&#34;成为活跃的。

如何做到这一点?

2 个答案:

答案 0 :(得分:12)

您需要在ui-tabset上使用active属性。 然后,您需要在每个选项卡上都有索引才能从外部上下文中工作。

<uib-tabset type="pills" active="active">
    <uib-tab heading="Tab 1" index="0">Tab 1 content</uib-tab>
    <uib-tab heading="Tab 2" index="1">Tab 2 content</uib-tab>
</uib-tabset>

看到这个工作plnkr: Working Plnkr

答案 1 :(得分:2)

我遇到了同样的问题,这answer帮我解决了问题。

我在范围中使用了两个变量:$scope.showTabsInView$scope.activeTabIndex

默认值为:

$scope.showTabsInView = false;
$scope.activeTabIndex = 0;

首先,我加载了dynamic tabs,然后我指定了activeTabIndex的值。然后我将showTabsInView的值更改为true。

<uib-tabset ng-if="showTabsInView" active="activeTabIndex">
    <uib-tab data-ng-repeat="tab in tabs" heading="{{tab.title}}">{{tab.content}}</uib-tab>
</uib-tabset>

如果你的情况不那么复杂,你可以忽略dynamic tabs$scope.showTabsInView