如何记住使用cookie显示和隐藏div

时间:2013-12-25 07:35:40

标签: javascript jquery html css cookies

我喜欢HTML:

<div id='mainleft-content'>content is visible</div>
<div id="expand-hidden">Button Expand +</div>

我使用Jquery来显示/隐藏div,如:

 $(document).ready(function () {
    $("#expand-hidden").click(function () {
        $("#mainleft-content").toggle();
    });
});

我想使用cookie记住div的状态是隐藏或显示访问者的操纵。

我该怎么办?谢谢你的帮助。

请参阅JSFIDDLE

3 个答案:

答案 0 :(得分:3)

Here is working fiddle

您可以将is(":visible")用于此目的,无论div是否可见,它都会返回给您:

if ( $("#mainleft-content").is(":visible") ){
   alert('its visible');
}
else{
   alert('div is hidden');
}

如果您仍然需要cookie,您可以添加一个功能:

function setCookie(c_name, value, exdays) {
    var exdate = new Date();
    exdate.setDate(exdate.getDate() + exdays);
    var c_value = escape(value) + ((exdays == null) ? "" : "; expires=" + exdate.toUTCString());
    document.cookie = c_name + "=" + c_value;
}

function getCookie(c_name) {
    var i, x, y, ARRcookies = document.cookie.split(";");
    for (i = 0; i < ARRcookies.length; i++) {
        x = ARRcookies[i].substr(0, ARRcookies[i].indexOf("="));
        y = ARRcookies[i].substr(ARRcookies[i].indexOf("=") + 1);
        x = x.replace(/^\s+|\s+$/g, "");
        if (x == c_name) {
            return unescape(y);
        }
    }
}

并设置cookie:

$(document).ready(function () {
    $("#expand-hidden").click(function () {
        $("#mainleft-content").toggle();
        SetCookie("DivStateVisible", $("#mainleft-content").is(":visible"),5);
    });
});

jQuery 使用jquery-cookie

function setCookie(c_name, value, exdays) {
    $.cookie(c_name, value, { expires : exdays });
}

function getCookie(c_name) {
    return $.cookie(c_name);
}

答案 1 :(得分:2)

使用http://plugins.jquery.com/cookie/

$(document).ready(function () {
    $("#mainleft-content").toggle(!!$.cookie("visible"));
    $("#expand-hidden").click(function () {
        $("#mainleft-content").toggle(function() { 
             $.cookie("visible", $("#mainleft-content").is(':visible') ? 1 : 0);
        });
    });
});

答案 2 :(得分:1)

你可以使用插件: https://github.com/carhartl/jquery-cookie

并设置像

这样的状态
$.cookie("visible", 1);