我喜欢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
答案 0 :(得分:3)
您可以将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)