0

我正在为每个单击的导航容器设置一个 cookie。

它设置一个连接的数组并设置 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);
}

}
});
4

1 回答 1

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

读作:

for element in setCookieHelper

此元素可能不是 int 并且会导致拼接失败,此外,您必须检查元素是否包含要拼接的位置,然后您必须在尝试拼接之前检查它的值是否在 setCookieHelper 长度内。

如果要在给定位置拼接,则应使用 for:

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

splice 需要一个开始“拼接”的索引和“拼接”元素的数量。

于 2010-04-15T17:49:40.130 回答