如何在记住隐藏的停靠状态时添加cookie会话?

时间:2013-02-05 17:49:34

标签: jquery cookies

您如何将Cookie代码添加到我目前的代码中?我一直在阅读,但我不是最好的jQuery。

http://jsfiddle.net/k9vAJ/

代码:

$(document).ready(function () {
    var visible = true;
    $("#docktoggle").on('click', function() { 
        $('.dock')
            .animate({ width: visible ? 0 : 980 }, "slow")
            .css({ display: visible ? "none" : "" })
            .css({ width: visible ? "none" : "100% !important" });
        visible = !visible;  
    });
});

$(function(){
    $(".img-swap").live('click', function() {
        if ($(this).attr("class") == "img-swap") {
            this.src = this.src.replace("_on","_off");
        } 
        else {
            this.src = this.src.replace("_off","_on");
        }
        $(this).toggleClass("on");
    });
});

1 个答案:

答案 0 :(得分:0)

@ user2041167:

您可能想要使用jQuery插件,我认为还有一些对此文件的引用。我知道这是因为我已经将它用于jstree jQuery插件,因为它与它一起打包。该插件处理与为cookie定义的原型进行交互,最终保存,如果没有错误进入浏览器。

            /**
             * Cookie plugin
             *
             * Copyright (c) 2006 Klaus Hartl (stilbuero.de)
             * Dual licensed under the MIT and GPL licenses:
             * http://www.opensource.org/licenses/mit-license.php
             * http://www.gnu.org/licenses/gpl.html
             *
             */

            /**
             * Create a cookie with the given name and value and other optional parameters.
             *
             * @example $.cookie('the_cookie', 'the_value');
             * @desc Set the value of a cookie.
             * @example $.cookie('the_cookie', 'the_value', { expires: 7, path: '/', domain: 'jquery.com', secure: true });
             * @desc Create a cookie with all available options.
             * @example $.cookie('the_cookie', 'the_value');
             * @desc Create a session cookie.
             * @example $.cookie('the_cookie', null);
             * @desc Delete a cookie by passing null as value. Keep in mind that you have to use the same path and domain
             *       used when the cookie was set.
             *
             * @param String name The name of the cookie.
             * @param String value The value of the cookie.
             * @param Object options An object literal containing key/value pairs to provide optional cookie attributes.
             * @option Number|Date expires Either an integer specifying the expiration date from now on in days or a Date object.
             *                             If a negative value is specified (e.g. a date in the past), the cookie will be deleted.
             *                             If set to null or omitted, the cookie will be a session cookie and will not be retained
             *                             when the the browser exits.
             * @option String path The value of the path atribute of the cookie (default: path of page that created the cookie).
             * @option String domain The value of the domain attribute of the cookie (default: domain of page that created the cookie).
             * @option Boolean secure If true, the secure attribute of the cookie will be set and the cookie transmission will
             *                        require a secure protocol (like HTTPS).
             * @type undefined
             *
             * @name $.cookie
             * @cat Plugins/Cookie
             * @author Klaus Hartl/klaus.hartl@stilbuero.de
             */

            /**
             * Get the value of a cookie with the given name.
             *
             * @example $.cookie('the_cookie');
             * @desc Get the value of a cookie.
             *
             * @param String name The name of the cookie.
             * @return The value of the cookie.
             * @type String
             *
             * @name $.cookie
             * @cat Plugins/Cookie
             * @author Klaus Hartl/klaus.hartl@stilbuero.de
             */
            jQuery.cookie = function(name, value, options) {
                if (typeof value != 'undefined') { // name and value given, set cookie
                    options = options || {};
                    if (value === null) {
                        value = '';
                        options.expires = -1;
                    }
                    var expires = '';
                    if (options.expires && (typeof options.expires == 'number' || options.expires.toUTCString)) {
                        var date;
                        if (typeof options.expires == 'number') {
                            date = new Date();
                            date.setTime(date.getTime() + (options.expires * 24 * 60 * 60 * 1000));
                        } else {
                            date = options.expires;
                        }
                        expires = '; expires=' + date.toUTCString(); // use expires attribute, max-age is not supported by IE
                    }
                    // CAUTION: Needed to parenthesize options.path and options.domain
                    // in the following expressions, otherwise they evaluate to undefined
                    // in the packed version for some reason...
                    var path = options.path ? '; path=' + (options.path) : '';
                    var domain = options.domain ? '; domain=' + (options.domain) : '';
                    var secure = options.secure ? '; secure' : '';
                    document.cookie = [name, '=', encodeURIComponent(value), expires, path, domain, secure].join('');
                } else { // only name given, get cookie
                    var cookieValue = null;
                    if (document.cookie && document.cookie != '') {
                        var cookies = document.cookie.split(';');
                        for (var i = 0; i < cookies.length; i++) {
                            var cookie = jQuery.trim(cookies[i]);
                            // Does this cookie string begin with the name we want?
                            if (cookie.substring(0, name.length + 1) == (name + '=')) {
                                cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
                                break;
                            }
                        }
                    }
                    return cookieValue;
                }
            };