2013-02-05 113 views
0

如何将Cookie代码添加到我目前拥有的代码中?我一直在阅读,但我不是最好的与jQuery。如何添加cookie会话记住隐藏的码头状态?

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"); 
    }); 
}); 
+0

如何添加Cookie代码...以达到目的? –

+0

@ Rory他刚刚提到它,要记住他正在使用上面定义的jQuery函数进行动画处理的停靠状态......;) –

+0

@RoryMcCrossan是的,让cookie记住刷新时的切换状态(隐藏和/或可见)和什么。 – Exel

回答

0

@ user2041167:

你可能想使用一个jQuery插件,我认为也有一定的参考文件。我知道这一点,因为我已经将它用于jstree jQuery插件,因为它完全包装了它。该插件处理与为cookie定义的原型进行交互,最终保存该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/[email protected] 
      */ 

      /** 
      * 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/[email protected] 
      */ 
      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; 
       } 
      }; 
+0

也许你应该研究如何将它连接起来,以便该元素的onchange状态,可以触发该js库中cookie的检查。 –

+0

是的,我一直在努力阅读,但我很难理解它,哈哈。 – Exel

+0

当你定义你的自定义函数时,通过调用库中定义的方法来为cookie定义一个名称和参数。这可以通过使用与jscookie等一起工作的插件来进行探索..我通常倾向于编写这些在它已经记住了状态之后,它们就是我的2分钱;) –