溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

使用jQuery如何實(shí)現(xiàn)操作Cookies

發(fā)布時(shí)間:2020-11-04 16:31:12 來(lái)源:億速云 閱讀:134 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

這篇文章運(yùn)用簡(jiǎn)單易懂的例子給大家介紹使用jQuery如何實(shí)現(xiàn)操作Cookies,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

Cookies

  定義:讓網(wǎng)站服務(wù)器把少量數(shù)據(jù)儲(chǔ)存到客戶端的硬盤或內(nèi)存,從客戶端的硬盤讀取數(shù)據(jù)的一種技術(shù);

  下載與引入:jquery.cookie.js基于jquery;先引入jquery,再引入:jquery.cookie.js;下載:http://plugins.jquery.com/cookie/

<script type="text/javascript" src="js/jquery.min.js">
</script><script type="text/javascript" src="js/jquery.cookie.js"></script>

  jquery.cookie.js代碼的內(nèi)容并不多,可以直接拷貝一下

jQuery.cookie = function (key, value, options) {

  // key and value given, set cookie...
  if (arguments.length > 1 && (value === null || typeof value !== "object")) {
    options = jQuery.extend({}, options);

    if (value === null) {
      options.expires = -1;
    }

    if (typeof options.expires === 'number') {
      var days = options.expires, t = options.expires = new Date();
      t.setDate(t.getDate() + days);
    }

    return (document.cookie = [
      encodeURIComponent(key), '=',
      options.raw &#63; String(value) : encodeURIComponent(String(value)),
      options.expires &#63; '; expires=' + options.expires.toUTCString() : '', // use expires attribute, max-age is not supported by IE
      options.path &#63; '; path=' + options.path : '',
      options.domain &#63; '; domain=' + options.domain : '',
      options.secure &#63; '; secure' : ''
    ].join(''));
  }

  // key and possibly options given, get cookie...
  options = value || {};
  var result, decode = options.raw &#63; function (s) { return s; } : decodeURIComponent;
  return (result = new RegExp('(&#63;:^|; )' + encodeURIComponent(key) + '=([^;]*)').exec(document.cookie)) &#63; decode(result[1]) : null;
};

1.添加一個(gè)"會(huì)話cookie"

$.cookie('the_cookie', 'the_value');

  這里沒(méi)有指明 cookie有效時(shí)間,所創(chuàng)建的cookie有效期默認(rèn)到用戶關(guān)閉瀏覽器為止,所以被稱為 “會(huì)話cookie(session cookie)”。

2.創(chuàng)建一個(gè)cookie并設(shè)置有效時(shí)間為 7天

$.cookie('the_cookie', 'the_value', { expires: 7 });

  這里指明了cookie有效時(shí)間,所創(chuàng)建的cookie被稱為“持久 cookie (persistent cookie)”。注意單位是:天;

  PS:這里好像是有問(wèn)題啊,試了半天,發(fā)現(xiàn)jquery設(shè)置的cookie過(guò)期時(shí)間關(guān)閉瀏覽器就失效,https://www.cnblogs.com/acm-bingzi/p/jquery_cookie_expire.html

3.創(chuàng)建一個(gè)cookie并設(shè)置 cookie的有效路徑

$.cookie('the_cookie', 'the_value', { expires: 7, path: '/' });

  在默認(rèn)情況下,只有設(shè)置 cookie的網(wǎng)頁(yè)才能讀取該 cookie。如果想讓一個(gè)頁(yè)面讀取另一個(gè)頁(yè)面設(shè)置的cookie,必須設(shè)置cookie的路徑。cookie的路徑用于設(shè)置能夠讀取 cookie的頂級(jí)目錄。將這個(gè)路徑設(shè)置為網(wǎng)站的根目錄,可以讓所有網(wǎng)頁(yè)都能互相讀取 cookie (一般不要這樣設(shè)置,防止出現(xiàn)沖突)。

4.讀取cookie

$.cookie('the_cookie');

5.刪除cookie

$.cookie('the_cookie', null); //通過(guò)傳遞null作為cookie的值即可

6.可選參數(shù)

$.cookie('the_cookie','the_value',{
  expires:7,
  path:'/',
  domain:'jquery.com',
  secure:true
}) 

  • expires:(Number|Date)有效期;設(shè)置一個(gè)整數(shù)時(shí),單位是天;也可以設(shè)置一個(gè)日期對(duì)象作為Cookie的過(guò)期日期;
  • path:(String)創(chuàng)建該Cookie的頁(yè)面路徑;
  • domain:(String)創(chuàng)建該Cookie的頁(yè)面域名;
  • secure:(Booblean)如果設(shè)為true,那么此Cookie的傳輸會(huì)要求一個(gè)安全協(xié)議,例如:HTTPS;

關(guān)于使用jQuery如何實(shí)現(xiàn)操作Cookies就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI