ページのヘッダーを切り替える次の JQuery があります。JQuery Cookie を使用してトグル状態を記憶するにはどうすればよいですか?
$(document).ready(function() {
$('#btnToggleHeader').click(function() {
$('#Header').slideToggle('slow');
});
});
どうもありがとうございました!
ページのヘッダーを切り替える次の JQuery があります。JQuery Cookie を使用してトグル状態を記憶するにはどうすればよいですか?
$(document).ready(function() {
$('#btnToggleHeader').click(function() {
$('#Header').slideToggle('slow');
});
});
どうもありがとうございました!
JavaScript と Cookie に関する優れたリソースはhttp://www.w3schools.com/JS/js_cookies.aspです。
この Web サイトに基づいて、setCookie、getCookie、checkCookie の 3 つの関数が提供されます (他の 2 つの使用方法のデモが表示されます)。
トグルの初期状態を設定するには、次のようにします。
$(document).ready(function(){
// The initial load event will try and pull the cookie to see if the toggle is "open"
var openToggle = getCookie("open") || false;
if ( openToggle )
$("#Header").show();
else
$("#Header").hide();
// The click handler will decide whether the toggle should "show"/"hide" and set the cookie.
$('#btnToggleHeader').click(function() {
var closed = $("#Header").is(":hidden");
if ( closed )
$("#Header").show();
else
$("#Header").hide();
setCookie("open", !closed, 365 );
});
});
注: これは単なる参照であり、テストする時間がありませんでした。それが役に立ったことを願っています。
最終的な作業バージョンは次のとおりです。
$(document).ready(function () {
$("#btnSearchToggle").click(function () {
var closed = $("#Header").is(":hidden");
if (closed)
$("#Header").show();
else
$("#Header").hide();
setCookie("open", closed, 365);
});
var openToggle = getCookie("open");
if (openToggle=="true") {
$("#Header").show();
}
else {
$("#Header").hide();
}
});
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);
}
}
}