我有一个jQuery UI手风琴,我需要记住它的状态(最后打开哪个标题)。
以下是我的观点:
var storedActive = localStorage.getItem("storedActive");
if (isNaN(storedActive)){
storedActive = false;
}
console.log(storedActive);
jQuery('#accordion').accordion({
heightStyle: "content",
collapsible: true,
header: 'h4',
active: storedActive,
activate: function(event, ui){
if(ui.newHeader.context){
storedActive = ui.newHeader.context.id.slice(-1); //getting id of clicked header
}else{
storedActive = false;
}
localStorage.setItem("storedActive", storedActive);
}
});
第5行中的console.log(storedActive)
证明最后点击的标题的值会被记住并正确地重新标记。问题是手风琴没有打开任何标题。
奇怪的是,当我手动设置值storedActive
时,accordion会按原样打开标题。当从localStorage恢复值时,它只是有一些问题。
答案 0 :(得分:1)
我从localStorage获取变量时忘了使用parseInt。现在一切正常。 Thx Ninsly!
var storedActive = parseInt(localStorage.getItem("storedActive"));
if (isNaN(storedActive)){
storedActive = false;
}
console.log(storedActive);
jQuery('#accordion').accordion({
heightStyle: "content",
collapsible: true,
header: 'h4',
active: storedActive,
activate: function(event, ui){
if(ui.newHeader.context){
storedActive = ui.newHeader.context.id.slice(-1); //getting id of clicked header
}else{
storedActive = false;
}
localStorage.setItem("storedActive", storedActive);
}
});
答案 1 :(得分:1)
我用这个:
$( ".accordion" ).accordion({
activate: function(event, ui) {
localStorage.setItem("AccordionId", $(this).accordion("option", "active"))
},
active: parseInt(localStorage.getItem("AccordionId"))
}
如果您的页面中有多个手风琴,请将“AccordionId”替换为此手风琴的唯一ID。
它也适用于Jquery Tabs