所有其他答案都是正确的。这个答案将考虑到一个人可能有多个ul.nav.nav-pills
或ul.nav.nav-tabs
在同一页面上的事实。在这种情况下,之前的答案将失败。
仍在使用localStorage
但将字符串JSON
化为值。这是代码:
$(function() {
var json, tabsState;
$('a[data-toggle="pill"], a[data-toggle="tab"]').on('shown', function(e) {
var href, json, parentId, tabsState;
tabsState = localStorage.getItem("tabs-state");
json = JSON.parse(tabsState || "{}");
parentId = $(e.target).parents("ul.nav.nav-pills, ul.nav.nav-tabs").attr("id");
href = $(e.target).attr('href');
json[parentId] = href;
return localStorage.setItem("tabs-state", JSON.stringify(json));
});
tabsState = localStorage.getItem("tabs-state");
json = JSON.parse(tabsState || "{}");
$.each(json, function(containerId, href) {
return $("#" + containerId + " a[href=" + href + "]").tab('show');
});
$("ul.nav.nav-pills, ul.nav.nav-tabs").each(function() {
var $this = $(this);
if (!json[$this.attr("id")]) {
return $this.find("a[data-toggle=tab]:first, a[data-toggle=pill]:first").tab("show");
}
});
});
这个位可以在整个应用程序的所有页面上使用,并且适用于选项卡和药丸。此外,请确保默认情况下选项卡或药丸未处于活动状态,否则您将在页面加载时看到闪烁效果。
重要提示:确保父母ul
有一个 id。谢谢阿兰