2013-02-05 39 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分錢;) –