2010-04-15 93 views
0

我正在为每个点击的导航容器设置一个cookie。splice()无法正常工作

它设置一个连接并设置cookie值的数组。 如果再次点击,则将其从数组中移除。

它以某种方式越野车。

它只在点击其他元素后才会拼接。然后它表现奇怪。

这可能是splice是不正确的方法

var navLinkToOpen; 
var setNavCookie = function(value){ 
var isSet = false; 
var checkCookies = checkNavCookie() 
    setCookieHelper = checkCookies? checkCookies.split(","): []; 
    for(i in setCookieHelper){ 
    if(value == setCookieHelper[i]){ 
     setCookieHelper.splice(value,1); 
     isSet = true; 
} 
} 
if(!isSet){setCookieHelper.push(value)} 
setCookieHelper.join(",") 
document.cookie = "navLinkToOpen"+"="+setCookieHelper; 
} 


var checkNavCookie = function(){ 
var allCookies = document.cookie.split(';'); 
for (i = 0; i < allCookies.length; i++){ 
temp = allCookies[i].split("=") 
if(temp[0].match("navLinkToOpen")){ 
    var getValue = temp[1] 
    } 
} 
return getValue || false 
} 



$(document).ready(function() { 
    $("#LeftNav li").has("b").addClass("navHeader").not(":first").siblings("li").hide() 
    $(".navHeader").click(function(){ 
$(this).toggleClass("collapsed").nextUntil("li:has('b')").slideToggle(300); 
setNavCookie($('.navHeader').index($(this))) 
return false 
    }) 

var testCookies = checkNavCookie(); 
if(testCookies){ 
finalArrayValue = testCookies.split(",") 
for(i in finalArrayValue){ 
$(".navHeader").eq(finalArrayValue[i]).toggleClass("collapsed").nextUntil(".navHeader").slideToggle (0); 
} 

} 
}); 

回答

2
for(i in setCookieHelper){ 
    if(value == setCookieHelper[i]){ 

全文:

for element in setCookieHelper 

这个元素可能不是一个int而导致您的拼接失败,也您必须检查元素是否包含您要拼接的位置,然后在尝试拼接之前,您必须检查它的值是否在setCookieHelper的长度范围内。

,如果你想在你应该使用一个给定的位置,以拼接为一个:

for(i=0;i<setCookieHelper.lenght;i++){ 
    if(value == setCookieHelper[i]){ 
     setCookieHelper.splice(i,1); 
     isSet = true; 
    } 
} 

拼接预期指数从哪里开始“拼接”和“拼接”元素的量。

+0

谢谢,我听到你在说什么......也许我没有使用正确的方法'splice()'。我想要的只是需要删除找到的号码。 – adardesign 2010-04-15 17:56:37

+1

是啊,这是你想要的:)只是把它取代为一个正常的我固定最后一个正是你需要:) – fmsf 2010-04-15 18:42:15