JavaScript設(shè)置、獲取、清除單值和多值cookie的方法
廢話不多說(shuō)了,直接給大家貼代碼了。
具體代碼如下:
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è)置默認(rèn)過(guò)期時(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)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
JavaScript實(shí)現(xiàn)枚舉的幾種方法總結(jié)
在前端開(kāi)發(fā)中,我們可能經(jīng)常需要用到枚舉,使用枚舉的好處是為了讓代碼的可讀性更強(qiáng),避免直接使用數(shù)字或未知的字符串,但是在JavaScript中,要自己實(shí)現(xiàn)一個(gè)枚舉功能,那么大家能想到多少種實(shí)現(xiàn)枚舉的方法呢,我將介紹幾種實(shí)現(xiàn)枚舉的好方法2023-08-08
小程序開(kāi)發(fā)實(shí)現(xiàn)access_token統(tǒng)一管理
本文主要介紹了小程序開(kāi)發(fā)實(shí)現(xiàn)access_token統(tǒng)一管理,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-07-07
JavaScript深度復(fù)制(deep clone)的實(shí)現(xiàn)方法
本文給大家介紹JavaScript深度復(fù)制(deep clone)的實(shí)現(xiàn)方法,涉及到j(luò)s深度復(fù)制相關(guān)知識(shí),本文介紹的非常詳細(xì),特此分享腳本之家平臺(tái)供大家參考2016-02-02
vscode錄音及語(yǔ)音實(shí)時(shí)轉(zhuǎn)寫(xiě)插件開(kāi)發(fā)并在工作區(qū)生成本地mp3文件附踩坑日記!
以目前的vscode版本來(lái)說(shuō),作者并沒(méi)有開(kāi)放訪問(wèn)本地媒體權(quán)限,所以插件市場(chǎng)里面的所有語(yǔ)音相關(guān)插件也并沒(méi)有直接獲取vscode的媒體權(quán)限,這篇文章主要介紹了vscode錄音及語(yǔ)音實(shí)時(shí)轉(zhuǎn)寫(xiě)插件開(kāi)發(fā)并在工作區(qū)生成本地mp3文件?踩坑日記!,需要的朋友可以參考下2023-05-05
認(rèn)識(shí)Knockout及如何使用Knockout綁定上下文
Knockout簡(jiǎn)稱ko,是一個(gè)輕量級(jí)的javascript類庫(kù),采用MVVM設(shè)計(jì)模式(即Model、view、viewModel),簡(jiǎn)單優(yōu)雅的實(shí)現(xiàn)了雙向綁定,實(shí)時(shí)更新,幫助您使用干凈的數(shù)據(jù)模型來(lái)創(chuàng)建豐富的、響應(yīng)式的用戶界面2015-12-12
jquery div模態(tài)窗口的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇jquery div模態(tài)窗口的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-05-05
Javascript別踩白塊兒(鋼琴塊兒)小游戲?qū)崿F(xiàn)代碼
游戲唯一的一個(gè)規(guī)則,我們只需要不斷踩著黑色方塊前進(jìn)即可,這里根據(jù)方向鍵來(lái)踩白塊,在規(guī)定的時(shí)間內(nèi),每走一次分?jǐn)?shù)加100.下面通過(guò)本文給大家分享Javascript別踩白塊兒(鋼琴塊兒)小游戲?qū)崿F(xiàn)代碼,一起看看吧2017-07-07

