堆叠时使用活动引导选项卡

时间:2016-04-21 19:15:25

标签: jquery css twitter-bootstrap

对于我正在处理的新引导程序网站,我在nav-tab堆栈时对活动选项卡进行排序,以便所选选项卡始终连接到选项卡窗格。虽然这有效,但对我来说感觉就像是黑客。有没有更好的方法来保留原始Tab键顺序?

Html标记:

<div id="tab-bundle" class="container-fluid">
    @Html.HiddenFor(model => model.SelectedBundle)
    <ul class="nav nav-tabs" id="coverageTabs">
         <li><a href="#Minimum">@LanguageDb.Me.Minimum</a></li>
         <li><a href="#Better">@LanguageDb.Me.Better</a></li>
         <li><a href="#Best">@LanguageDb.Me.Best</a></li>
         <li><a href="#Custom">@LanguageDb.Me.Custom</a></li>
    </ul>

    <div class="tab-content">
         <div class="tab-pane active bg-info" id="ajaxPanel">
            @Html.Partial("SelectedBundle", Model)
         </div>
    </div>
</div>

使用Javascript:

$(document).ready(function () {

    var updateCoverage = function (e) {
        e.preventDefault();
        var $tab = $(this);
        $('#SelectedBundle').val($(this).attr("href").substr(1));
        $('#coverageTabs a').css({ backgroundColor: "", color: "" });

        // ajax omitted for brevity
        $tab.tab('show').css('background-color', $('#ajaxPanel').css('background-color')).css('color', $('#ajaxPanel').css('color'));

        if ( $('#coverageTabs').width() < 768 ) {
          $tab.closest('li').appendTo('#coverageTabs');
        }
    };

    $('a[href=#' + $('#SelectedBundle').val() + ']').tab('show').css('background-color', $('#ajaxPanel').css('background-color')).css('color', $('#ajaxPanel').css('color')); ;

    $('#coverageTabs a').click(updateCoverage);

});

屏幕截图(注意最小标签已移至末尾): Reordered Tab example

1 个答案:

答案 0 :(得分:1)

这让我想起了刚才回答的一个问题:

Unordered list - list item position

我们的想法是,只需要很少的JavaScript,即添加和删除“活跃”类,我们仍然可以实现您的目标:

您的CSS可能包含以下内容:

ul {
  display: flex;
}

li[class=active] {
  order: 4; /* whatever the last <li> slot is */
  background: green
}

然后,当您的JavaScript分配活动类时,<li class="active">应该神奇地将自己重新排序到列表的末尾并连接到选项卡窗格。