【问题标题】:Set cookie and get cookie with JavaScript [duplicate]使用 JavaScript 设置 cookie 和获取 cookie [重复]
【发布时间】:2017-09-05 05:43:01
【问题描述】:

我正在尝试根据我在 HTML 中选择的 CSS 文件设置一个 cookie。我有一个带有选项列表的表单,以及不同的 CSS 文件作为值。当我选择一个文件时,它应该被保存到一个 cookie 中大约一个星期。下次打开 HTML 文件时,它应该是您之前选择的文件。

JavaScript 代码:

function cssLayout() {
    document.getElementById("css").href = this.value;
}


function setCookie(){
    var date = new Date("Februari 10, 2013");
    var dateString = date.toGMTString();
    var cookieString = "Css=document.getElementById("css").href" + dateString;
    document.cookie = cookieString;
}

function getCookie(){
    alert(document.cookie);
}

HTML 代码:

<form>
    Select your css layout:<br>
    <select id="myList">
        <option value="style-1.css">CSS1</option>
        <option value="style-2.css">CSS2</option>  
        <option value="style-3.css">CSS3</option>
        <option value="style-4.css">CSS4</option>
    </select>
</form>

【问题讨论】:

  • kaka = "Css=document.getElementById("css").href" + kakdatum; 是语法错误。
  • 我想知道如何根据选择设置cookie。如果我选择一个特定的 css 文件,那么我希望在下次打开 html 文件时保存并激活该文件
  • @DrWooolie 如何将答案标记为正确,以便该问题的访问者找到最佳答案?最佳答案显然不是最好的。
  • 现在(2017 年),一些用例使得调查 Web Storage API 而不是 cookie 更有价值。
  • 在重复问题中获取/设置 cookie 的简洁但功能齐全的现代方法:stackoverflow.com/a/48706852/87520

标签: javascript html css cookies


【解决方案1】:

我发现以下代码比其他任何代码都简单得多:

function setCookie(name,value,days) {
    var expires = "";
    if (days) {
        var date = new Date();
        date.setTime(date.getTime() + (days*24*60*60*1000));
        expires = "; expires=" + date.toUTCString();
    }
    document.cookie = name + "=" + (value || "")  + expires + "; path=/";
}
function getCookie(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) {   
    document.cookie = name +'=; Path=/; Expires=Thu, 01 Jan 1970 00:00:01 GMT;';
}

现在,调用函数

setCookie('ppkcookie','testcookie',7);

var x = getCookie('ppkcookie');
if (x) {
    [do something with x]
}

来源 - http://www.quirksmode.org/js/cookies.html

他们今天更新了页面,所以页面中的所有内容都应该是最新的。

【讨论】:

  • toGMTString() 已弃用 - 仅供参考。 Reference
  • 如果您的 cookie 包含分号,这将不起作用。
  • 为什么这么复杂?请改用date.setDate(date.getDate() + days);
  • eraseCookie 功能对我不起作用(FireFox Developer Edition 66.0b4)。相反,我不得不使用 B T 答案中的代码:document.cookie = name + '=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/'
  • 不错的答案。在 cookie 值中使用分号(;)时我遇到了问题。所以我细化了一些线条。请更新您的答案。来自 function setCookie(name,value,days) document.cookie = name + "=" + (encodeURIComponent(value) || "") + expires + "; path=/"; From function getCookie(name) if (c.indexOf(nameEQ) == 0) return decodeURIComponent(c.substring(nameEQ.length,c.length)); 在 retutn 语句中使用 encodeURIComponent(), decodeURIComponent()
【解决方案2】:

这些是比 w3schools(有史以来最糟糕的网络参考)更好的参考很多

来自这些参考的示例:

// sets the cookie cookie1
document.cookie = 'cookie1=test; expires=Sun, 1 Jan 2023 00:00:00 UTC; path=/'

// sets the cookie cookie2 (cookie1 is *not* overwritten)
document.cookie = 'cookie2=test; expires=Sun, 1 Jan 2023 00:00:00 UTC; path=/'

// remove cookie2
document.cookie = 'cookie2=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/'

Mozilla 参考甚至有一个不错的 cookie 库可供您使用。

【讨论】:

  • expires 变量已过时,但仍受浏览器支持。请改用 max-age!
  • 好像IE8及以下不支持max-age,所以expires是比较安全的选择。 blogs.msdn.com/b/ieinternals/archive/2009/08/20/…
  • 还有一个 domain 参数,您可以在 cookie 上设置,如果您想在站点的不同子域中使用 cookie,这将非常有用。
  • 不要在 Chrome 上工作。在这里查看原因:stackoverflow.com/questions/26349052/…
  • 请注意,MDN 参考页面没有提到 expires 被弃用/过时。这是因为它有时可以用于max-age 未涵盖的目的。 max-age 的值必须是解释为秒数的数值,而expires 值可以设置为特殊值Session,它max-age=0; 不同 .
【解决方案3】:

检查 JavaScript Cookies on W3Schools.com 以通过 JS 设置和获取 cookie 值。

只需使用其中提到的 setCookie 和 getCookie 方法即可。

因此,代码将如下所示:

<script>
function setCookie(c_name, value, exdays) {
    var exdate = new Date();
    exdate.setDate(exdate.getDate() + exdays);
    var c_value = escape(value) + ((exdays == null) ? "" : "; expires=" + exdate.toUTCString());
    document.cookie = c_name + "=" + c_value;
}

function getCookie(c_name) {
    var i, x, y, ARRcookies = document.cookie.split(";");
    for (i = 0; i < ARRcookies.length; i++) {
        x = ARRcookies[i].substr(0, ARRcookies[i].indexOf("="));
        y = ARRcookies[i].substr(ARRcookies[i].indexOf("=") + 1);
        x = x.replace(/^\s+|\s+$/g, "");
        if (x == c_name) {
            return unescape(y);
        }
    }
}

function cssSelected() {
    var cssSelected = $('#myList')[0].value;
    if (cssSelected !== "select") {
        setCookie("selectedCSS", cssSelected, 3);
    }
}

$(document).ready(function() {
    $('#myList')[0].value = getCookie("selectedCSS");
})
</script>
<select id="myList" onchange="cssSelected();">
    <option value="select">--Select--</option>
    <option value="style-1.css">CSS1</option>
    <option value="style-2.css">CSS2</option>
    <option value="style-3.css">CSS3</option>
    <option value="style-4.css">CSS4</option>
</select>

【讨论】:

  • @BT 您能否详细说明上述代码已过时且信息错误?
  • @BT,我还没有看到关于 w3schools 的参考资料已经过时或包含不正确的信息。
  • -1 用于 w3schools
  • 我刚刚检查了我们的分析,我们 10% 的 IE 用户仍在使用 IE8 或更低版本。所以使用“max-age”是一个非常糟糕的主意。
  • 愚蠢!! +1 对于工作示例,我实际上没有看到 w3schools 的问题,
【解决方案4】:

我相信这个问题应该有一个更通用的答案,其中包含一些可重用的代码,这些代码将 cookie 用作键值对。

这个 sn-p 取自 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 < aKeys.length; nIdx++) { aKeys[nIdx] = decodeURIComponent(aKeys[nIdx]); }
    return aKeys;
  }
};

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

还有一个替代的 sn-p here:

【讨论】:

  • 只是警告@SandipPingle,此答案中提供的代码实际上是 GPL 许可的。
  • @MarcinHabuszewski 感谢您的指出。那我该如何使用这个代码(我的应用没有 GPL 许可)?
  • @SandipPingle 这就是 GPL 的“魅力”,你不能(除非你把你的应用变成 GPL)。这段代码有点类似于问题的通用解决方案,所以它引出了一个问题:通用代码实际上可以被许可(或者这种许可在通用代码的情况下是否有效)?尝试使用不同的(非 GPLed)代码来解决您的问题。
  • GPL 与否,我更喜欢我可以阅读的代码。
  • setItem 对我不起作用。我在chrome上测试过。其他方法工作正常。
猜你喜欢
  • 1970-01-01
  • 2014-01-03
  • 1970-01-01
  • 1970-01-01
  • 2013-01-28
  • 1970-01-01
相关资源
最近更新 更多