我正在为每个点击的导航容器设置一个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);
}
}
});
答案 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期望索引从哪里开始“拼接”和“拼接”元素的数量。