JavaScript設(shè)置、獲取、清除單值和多值cookie的方法
廢話不多說了,直接給大家貼代碼了。
具體代碼如下:
var CookieUtil = (function () { var Cookie = function () { // 獲取單值cookie this.get = function(name) { var start = document.cookie.indexOf(encodeURIComponent(name)) ; var end = document.cookie.indexOf(';', start) ; if(end == -) { end = document.cookie.length; } return decodeURIComponent(document.cookie.substring(start+name.length+,end)); }; // 設(shè)置單值cookie this.set = function(name, value, expires, path, domain, secure) { var cookieText = encodeURIComponent(name) + "=" + encodeURIComponent(value); // 設(shè)置默認過期時間為七天 if(expires == undefined) { var date = new Date(); date.setTime(date.getTime() + ****); expires = date ; } if(expires instanceof Date) { cookieText += "; expires=" + expires.toGMTString(); } if(path != undefined) { cookieText += "; path=" + path; } if(domain != undefined) { cookieText += "; domain" + domain; } if(secure != undefined) { cookieText += "; secure"; } document.cookie = cookieText; }; // 清除單值cookie this.unset = function(name, path, domain, secure) { this.set(name, '', new Date(), path, domain, secure ); }; // 設(shè)置多值cookie this.setAll = function(name, subCookies, expires, path, domain, secure) { var cookieText = ";" + encodeURIComponent(name) + "=", arr = new Array(); for(var attr in subCookies) { arr.push([encodeURIComponent(attr)] + ":" + encodeURIComponent(subCookies[attr])); } this.set(name, arr.join('&'), expires, path, domain, secure); }; // 獲取多值cookie this.getAll = function(name) { var obj = {}; var arr = this.get(name).split('&'); for(var i = , len = arr.length; i < len; i++) { var tmpArr = arr[i].split(':'); obj[decodeURIComponent(tmpArr[])] = decodeURIComponent(tmpArr[]); } return obj; }; // 獲取多值cookie的子cookie this.getSub = function(name, subname) { var obj = this.getAll(name); return obj[subname]; }; // 清除指定的多值cookie this.unsetAll = function(name,path,domain,secure) { this.unset(name, '', new Date(), path, domain, secure); }; // 清除指定多值cookie的子cookie this.unsetSub = function(name, subname,path, domain, secure) { var obj = this.getAll(name); delete obj[subname]; this.setAll(name, obj, null, path, domain, secure); }; }; return new Cookie(); })();
以上代碼就是本文給大家介紹JavaScript設(shè)置、獲取、清除單值和多值cookie的方法,有哪里不清楚的地方歡迎給我留言。
相關(guān)文章
JavaScript中工廠函數(shù)與構(gòu)造函數(shù)示例詳解
這篇文章主要給大家介紹了關(guān)于JavaScript中工廠函數(shù)與構(gòu)造函數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05JavaScript實現(xiàn)枚舉的幾種方法總結(jié)
在前端開發(fā)中,我們可能經(jīng)常需要用到枚舉,使用枚舉的好處是為了讓代碼的可讀性更強,避免直接使用數(shù)字或未知的字符串,但是在JavaScript中,要自己實現(xiàn)一個枚舉功能,那么大家能想到多少種實現(xiàn)枚舉的方法呢,我將介紹幾種實現(xiàn)枚舉的好方法2023-08-08小程序開發(fā)實現(xiàn)access_token統(tǒng)一管理
本文主要介紹了小程序開發(fā)實現(xiàn)access_token統(tǒng)一管理,文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-07-07JavaScript深度復(fù)制(deep clone)的實現(xiàn)方法
本文給大家介紹JavaScript深度復(fù)制(deep clone)的實現(xiàn)方法,涉及到j(luò)s深度復(fù)制相關(guān)知識,本文介紹的非常詳細,特此分享腳本之家平臺供大家參考2016-02-02vscode錄音及語音實時轉(zhuǎn)寫插件開發(fā)并在工作區(qū)生成本地mp3文件附踩坑日記!
以目前的vscode版本來說,作者并沒有開放訪問本地媒體權(quán)限,所以插件市場里面的所有語音相關(guān)插件也并沒有直接獲取vscode的媒體權(quán)限,這篇文章主要介紹了vscode錄音及語音實時轉(zhuǎn)寫插件開發(fā)并在工作區(qū)生成本地mp3文件?踩坑日記!,需要的朋友可以參考下2023-05-05Javascript別踩白塊兒(鋼琴塊兒)小游戲?qū)崿F(xiàn)代碼
游戲唯一的一個規(guī)則,我們只需要不斷踩著黑色方塊前進即可,這里根據(jù)方向鍵來踩白塊,在規(guī)定的時間內(nèi),每走一次分數(shù)加100.下面通過本文給大家分享Javascript別踩白塊兒(鋼琴塊兒)小游戲?qū)崿F(xiàn)代碼,一起看看吧2017-07-07