对于我正在处理的新引导程序网站,我在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);
});
答案 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">
应该神奇地将自己重新排序到列表的末尾并连接到选项卡窗格。