使用 JavaScript 获取和设置单个 cookie 值的“最佳”方法是什么

What is the "best" way to get and set a single cookie value using JavaScript

提问人:Jamey McElveen 提问时间:11/4/2008 最后编辑:Matthew SchinckelJamey McElveen 更新时间:6/18/2014 访问量:21662

问:

我想在每次引用页面时增加一个 cookie 值,即使该页面是从缓存加载的。实现这一点的“最佳”或最简洁的方法是什么?

JavaScript Cookie

评论


答:

7赞 Christian C. Salvadó 11/4/2008 #1

我见过的大多数旧的 cookie 处理函数都使用简单的字符串操作来存储检索值,就像这个例子一样,你可以使用其他库,比如 cookie-js,一个用于 cookie 访问的小型(< 100 行)实用程序。

我个人在我的项目上使用 jQuery,我使用 jQuery Cookie 插件,使用起来真的很简单:

var cookieName = "increment";

if ($.cookie(cookieName) == null){
  $.cookie(cookieName, 1, { expires: 10 });
}else{
  var newValue = Number($.cookie(cookieName)) + 1;
  $.cookie(cookieName, newValue, { expires: 10 });
}
31赞 nickf 11/4/2008 #2

http://www.quirksmode.org/js/cookies.html#script 偷来的

function createCookie(name,value,days) {
    if (days) {
        var date = new Date();
        date.setTime(date.getTime()+(days*24*60*60*1000));
        var expires = "; expires="+date.toUTCString();
    }
    else var expires = "";
    document.cookie = name+"="+value+expires+"; path=/";
}

function readCookie(name) {
    var nameEQ = name + "=";
    var ca = document.cookie.split(';');
    for(var i=0;i < ca.length;i++) {
        var c = ca[i];
        while (c.charAt(0)==' ') c = c.substring(1,c.length);
        if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
    }
    return null;
}

function eraseCookie(name) {
    createCookie(name,"",-1);
}

使用它:

var oldCount = parseInt(readCookie('hitCount'), 10) || 0;
createCookie('hitCount', oldCount + 1, 7);

正如评论中所指出的,您应该强制转换为 int,因为 cookie 是存储并作为字符串返回的。使用 or 实际上会为您投射,但确切地知道您正在使用的内容更安全:foo++++foo

var x = "5";  // x = "5" (string)
x += 1;       // x = "51" (string!)
x += 5;       // x = "515" (string!)
++x;          // x = 516 (number)

评论

0赞 Christian C. Salvadó 11/4/2008
readCookie 返回一个子字符串,你应该在递增 1 时将其转换为数字,否则你会得到 1、11、111、1111......
0赞 hultqvist 3/9/2012
您缺少 escape 和 unescape 的值
2赞 BeauCielBleu 6/18/2014
请注意,toGMTString 现在已被弃用,取而代之的是 toUTCString
2赞 Eugene Kuzmenko 4/17/2013 #3

最好的方法总是最简单的:

function getCookie(name) {
  return (name = (document.cookie + ';').match(new RegExp(name + '=.*;'))) && name[0].split(/=|;/)[1];
}

// the default lifetime is 365 days
function setCookie(name, value, days) {
  var e = new Date;
  e.setDate(e.getDate() + (days || 365));
  document.cookie = name + "=" + value + ';expires=' + e.toUTCString() + ';path=/;domain=.' + document.domain;
}

这些函数期望该值是一个简单的字符串,但如果您愿意,您始终可以对其进行 JSON.stringify 或对它执行其他操作......

评论

1赞 3/29/2019
对 getCookie +1 中的 1 行表示赞誉