JQuery - запомни состояние переключения с Cookie - PullRequest
1 голос
/ 19 апреля 2011

У меня есть следующий JQuery для переключения заголовка на моей странице.Как я могу использовать JQuery Cookie для запоминания состояния переключения?

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

Большое спасибо!

Ответы [ 2 ]

5 голосов
/ 19 апреля 2011

Хороший ресурс, касающийся JavaScript и файлов cookie, - 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 );
});

});

Примечание: это просто справка, у меня не было времени на тестирование.Надеюсь, это помогло.

0 голосов
/ 11 января 2013

Вот окончательная рабочая версия:

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