splice()无法正常工作

时间:2010-04-15 17:41:12

标签: javascript arrays cookies splice

我正在为每个点击的导航容器设置一个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);
}

}
});

1 个答案:

答案 0 :(得分: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期望索引从哪里开始“拼接”和“拼接”元素的数量。