html设置cookies使用,用JavaScript设置cookie并获得Cookie

我相信这个问题应该有一个更普遍的答案,使用一些可重用的代码,将cookie作为键值对使用。

这个片段是从MDN而且可能是可信的。这是用于使用cookie的UTF安全对象:var docCookies = {

getItem: function (sKey) {

return decodeURIComponent(document.cookie.replace(new RegExp("(?:(?:^|.*;)\\s*" + encodeURIComponent(sKey).replace(/[\-\.\+\*]/g,

"\\$&") + "\\s*\\=\\s*([^;]*).*$)|^.*$"), "$1")) || null;

},

setItem: function (sKey, sValue, vEnd, sPath, sDomain, bSecure) {

if (!sKey || /^(?:expires|max\-age|path|domain|secure)$/i.test(sKey)) { return false; }

var sExpires = "";

if (vEnd) {

switch (vEnd.constructor) {

case Number:

sExpires = vEnd === Infinity ? "; expires=Fri, 31 Dec 9999 23:59:59 GMT" : "; max-age=" + vEnd;

break;

case String:

sExpires = "; expires=" + vEnd;

break;

case Date:

sExpires = "; expires=" + vEnd.toUTCString();

break;

}

}

document.cookie = encodeURIComponent(sKey) + "=" + encodeURIComponent(sValue) + sExpires + (sDomain ? "; domain=" + sDomain : "")

+ (sPath ? "; path=" + sPath : "") + (bSecure ? "; secure" : "");

return true;

},

removeItem: function (sKey, sPath, sDomain) {

if (!sKey || !this.hasItem(sKey)) { return false; }

document.cookie = encodeURIComponent(sKey) + "=; expires=Thu, 01 Jan 1970 00:00:00 GMT" + ( sDomain ? "; domain=" + sDomain : "")

+ ( sPath ? "; path=" + sPath : "");

return true;

},

hasItem: function (sKey) {

return (new RegExp("(?:^|;\\s*)" + encodeURIComponent(sKey).replace(/[\-\.\+\*]/g, "\\$&") + "\\s*\\=")).test(document.cookie);

},

keys: /* optional method: you can safely remove it! */ function () {

var aKeys = document.cookie.replace(/((?:^|\s*;)[^\=]+)(?=;|$)|^\s*|\s*(?:\=[^;]*)?(?:\1|$)/g, "").split(/\s*(?:\=[^;]*)?;\s*/);

for (var nIdx = 0; nIdx 

return aKeys;

}};

Mozilla有一些测试来证明这在所有情况下都有效。

还有另一个片段这里:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值