Toutes les autres réponses sont correctes. Cette réponse prend en compte le fait que l'on peut avoir de multiples ul.nav.nav-pills
o ul.nav.nav-tabs
sur la même page. Dans ce cas, les réponses précédentes échoueront.
Utilisant toujours localStorage
mais avec un JSON
comme valeur. Voici le code :
$(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");
}
});
});
Cette mèche peut être utilisée sur l'ensemble de l'application, sur toutes les pages, et fonctionnera aussi bien pour les onglets que pour les pilules. Aussi, assurez-vous que les onglets ou les pilules ne sont pas actifs par défaut sinon vous verrez un effet de scintillement au chargement de la page.
Important : Assurez-vous que le parent ul
a un identifiant. Merci Alain
1 votes
Cette question semble faire double emploi avec la question suivante stackoverflow.com/questions/18999501/
0 votes
En rapport avec stackoverflow.com/questions/7862233/