溫馨提示×

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

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

javascript 中Cookie讀、寫與刪除操作的案例

發(fā)布時(shí)間:2020-10-14 15:02:43 來源:億速云 閱讀:102 作者:小新 欄目:web開發(fā)

這篇文章主要介紹javascript 中Cookie讀、寫與刪除操作的案例,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

javascript 中Cookie讀、寫與刪除操作

前言:

在這個(gè)前端橫行的時(shí)候,頁面之間的交互需要數(shù)據(jù)的傳遞,有的數(shù)據(jù)通過url傳參的形式可以很好地解決,但是對(duì)于部分需要改變的參數(shù),你如說從頁面A到頁面B選擇數(shù)據(jù),然后從頁面B將數(shù)據(jù)再傳到頁面A(典型的栗子就是收貨地址的選擇),針對(duì)這一塊我是通過存儲(chǔ)cookie來解決的。

對(duì)于cookie的操作我給出了一些簡(jiǎn)單的封裝,當(dāng)然也借鑒了前輩們經(jīng)驗(yàn),自己糅合了一下,對(duì)于cookie的操作,無非是讀寫和刪除,我們首先來看一下寫的操作,有寫才有讀,進(jìn)而進(jìn)行刪除等操作。

/**
 * 設(shè)置COOKIE
 * @param name 設(shè)置cookie的屬性名
 * @param value 設(shè)置cookie的屬性值
 * @param time  設(shè)置cookie的時(shí)間
 */

function setCookie(name, value , time) {
  time = time ? parseFloat(time) : 0 ;
  var exp = new Date();
  exp.setTime(exp.getTime() + time);
  // escape 這種編碼方式過時(shí)了 改用 encodeURIComponent
  // document.cookie = name + "=" + escape(value) + ";expires=" + (time ? exp.toGMTString() : 'session');
  document.cookie = name + "=" + encodeURIComponent(value) + ";expires=" + (time ? exp.toGMTString() : 'session');
}

我們有了寫的操作了,那么我們?cè)賮砜纯磳?duì)于讀的操作。

/**
 * 獲取cookie
 * @param name
 * @returns {null}
 */

function getCookie(name) {
  var arr, reg = new RegExp("(^| )" + name + "=([^;]*)(;|$)");
  if (arr = document.cookie.match(reg))
    //unescape這種解碼方式好像過時(shí)了,可以采用decodeURIComponent解碼方式
    //return unescape(arr[2]);
     return decodeURIComponent(arr[2]);
  else
    return null;
}

接下就是對(duì)cookie的刪除操作了,其實(shí)這個(gè)操作很簡(jiǎn)單,就是將cookie設(shè)置過期,cookie就自動(dòng)失效了

/**
 * 刪除cookie
 * @param name
 */

function delCookie(name) {
  var exp = new Date();
  exp.setTime(exp.getTime() - 1);
  var cval = getCookie(name);
  if (cval != null)
    document.cookie = name + "=" + cval + ";expires=" + exp.toGMTString();
}

以上就是對(duì)cookie的一些簡(jiǎn)單操作

接下來我們來談一點(diǎn)cookie的深層次的問題:cookie的跨域

 Js跨域同步cookie怎么實(shí)現(xiàn)
    document.cookie = "name=" + "value;" + "expires=" + "datatime;" + "domain=" + "" + "path=" + "/path" + "; secure";

/**
 * 刪除cookie
 * value Cookie值
 * expires 有效期截至(單位毫秒)
 * path 子目錄
 * domain 有效域
 * secure 是否安全
 */

<iframe src='http://網(wǎng)站:1234/test/Index' width='100' height='100' style="display:none"></iframe>

/*
*原頁面js里 window.location = "http://另外一個(gè)網(wǎng)站:1234/GetCookie/Index?" + document.cookie;跳到另外一個(gè)站,另外一個(gè)站獲取cookie,設(shè)置cookie
*/

 var url = window.location.toString();//獲取地址
 var get = url.substring(url.indexOf("liuph"));//獲取變量和變量值
 var idx = get.indexOf("=");//獲取變量名長(zhǎng)度
 if (idx != -1) {
    var name = get.substring(0, idx);//獲取變量名
    var val = get.substring(idx + 1);//獲取變量值
    setCookie(name, val, 1);//創(chuàng)建Cookie
  }

以上是javascript 中Cookie讀、寫與刪除操作的案例的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(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