JQuery - 使用 Cookie 记住切换状态

发布于 2024-11-02 11:26:45 字数 221 浏览 5 评论 0原文

我有以下 JQuery 来切换页面上的标题。如何使用 JQuery Cookie 记住切换状态?

$(document).ready(function() {
    $('#btnToggleHeader').click(function() {
    $('#Header').slideToggle('slow');
    });
});

非常感谢!

I have the following JQuery to toggle the header on my page. How can I use JQuery Cookie to remember the toggle state?

$(document).ready(function() {
    $('#btnToggleHeader').click(function() {
    $('#Header').slideToggle('slow');
    });
});

Thank you very much!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

耀眼的星火 2024-11-09 11:26:45

关于 javascript 和 cookies 的一个很好的资源是 http://www.w3schools.com/JS/js_cookies.asp

基于这个网站,我们获得了 3 个函数:setCookie、getCookie 和 checkCookie(它为我们提供了如何使用其他两个函数的演示。)

要设置切换的初始状态,可以使用以下方法:

$(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 );
});

});

注意:这只是一个参考一下,我没时间测试。希望有帮助。

A good resource regarding javascript and cookies is http://www.w3schools.com/JS/js_cookies.asp.

Based on this website we are given 3 functions: setCookie, getCookie and checkCookie (which gives us a demo of how to use the other two.)

To set the initial state of a toggle, something like this works:

$(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 );
});

});

Note: this is just a reference, I did not have time to test. Hope it helped.

无声情话 2024-11-09 11:26:45

这是最终的工作版本:

$(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);
        }
    }
}

Here is the final working version:

$(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);
        }
    }
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文