当前位置:   article > 正文

JS cookie的设置、获取和删除_js 删除cookie

js 删除cookie

JS 设置 Cookie

在 JavaScript 中,您可以通过document.cookie属性来创建、读取、修改和删除 Cookie 信息。

创建(设置)新的 Cookie 信息,需要以name=value形式的字符串来定义新的 Cookie 信息,如下例所示:

document.cookie = "url=http://c.biancheng.net/";

Cookie 数据中不能包含分号、逗号或空格,因此在将数据存储到 Cookie 之前,可以使用 JavaScript 内置的 encodeURIComponent() 函数对数据进行编码。在读取 Cookie 时,使用对应的 decodeURIComponent() 函数来解析 Cookie 数据,如下例所示:

document.cookie = "url=" + encodeURIComponent("http://c.biancheng.net/");

Cookie 并不会一直存在,默认情况下,Cookie 的生命周期就是浏览器的会话周期,即用户关闭浏览器后,Cookie 就会失效。 如果想要延长 Cookie 的生命周期,您可以使用 max-age 属性来指定 Cookie 可以存在的时间(单位为秒),默认为 -1,即关闭浏览器后失效。

 如果将 max-age 设置为一个负数,则表示该 Cookie 为临时 Cookie,关闭浏览器后就会失效。如果设置为 0,则表示删除该 Cookie。若要将 Cookie 的生命周期设置为 30 天的话,则可以像下面这样:

document.cookie = "url=http://c.biancheng.net/; max-age=" + 30*24*60*60;

此外,您也可以使用 expires 属性来指定 Cookie 失效的具体日期(GMT/UTC 格式),如下所示:

  1. var d = new Date();
  2. d.setTime(d.getTime()+(exdays*24*60*60*1000));
  3. var expires = "expires="+d.toGMTString();
  4. document.cookie = cname + "=" + cvalue + "; " + expires;
  5. document.cookie = "url=http://c.biancheng.net/; expires=Sun, 31 Dec 2017 12:00:00 UTC;";

默认情况下,Cookie 可用于同一域名下的所有网页,但如果您为 Cookie 设置了 path 属性,那么 Cookie 就只能在该域名指定路径下的网页中使用,例如网站的域名为 c.biancheng.net,若 path 属性设置为/,则表示 Cookie 可在域名下的所有网页中使用,若 path 属性设置为/javascript/,则 Cookie 只可在 http://c.biancheng.net/javascript/ 下的网页中使用,示例代码如下:

  1. document.cookie = "url=http://c.biancheng.net/; path=/";

如果您希望 Cookie 可以在指定域名下的子域名中使用,则可以通过 domain 属性来设置,默认情况下,Cookie 仅可在设置它的域名下使用,示例代码如下:
 

  1. document.cookie = "url=http://c.biancheng.net/; path=/; domain=.biancheng.net";

若将 domain 属性设置为.biancheng.net,则表示 Cookie 可在所有以biancheng.net结尾的域名下使用,注意,domain 属性值的第一个字符.不能省略。


此外,Cookie 中还有一个属性 secure,该属性只有一个属性名,没有属性值,如果设置了该属性,则表示 Cookie 将仅通过 HTTPS 协议传输,示例代码如下:

  1. document.cookie = "url=http://c.biancheng.net/; path=/; domain=.biancheng.net; secure";

为了方便设置 Cookie,我们可以定义一个函数,如下所示

  1. function setCookie(name, value, daysToLive) {
  2. // 对 cookie 值进行编码以转义其中的分号、逗号和空格
  3. var cookie = name + "=" + encodeURIComponent(value);
  4. if(typeof daysToLive === "number") {
  5. /* 设置 max-age 属性 */
  6. cookie += "; max-age=" + (daysToLive*24*60*60);
  7. }
  8. document.cookie = cookie;
  9. }

JS 获取 Cookie 

读取(获取) Cookie 同样使用document.cookie即可,该属性会返回一个字符串,字符串中包含除 max-age、expires、path 和 domain 等属性之外的所有 Cookie 信息,例如url=http://c.biancheng.net/; course=JavaScript。为了获取单个 Cookie 的值,我们可以通过 split() 函数将包含 Cookie 信息的字符串拆分为数组,然后再获取某个 Cookie 的值,示例代码

  1. document.cookie = "url=http://c.biancheng.net/; max-age=" + 30*24*60*60;
  2. document.cookie = "course=JavaScript";
  3. document.cookie = "title=cookie";
  4. function getCookie(name) {
  5. // 拆分 cookie 字符串
  6. var cookieArr = document.cookie.split(";");
  7. // 循环遍历数组元素
  8. for(var i = 0; i < cookieArr.length; i++) {
  9. var cookiePair = cookieArr[i].split("=");
  10. /* 删除 cookie 名称开头的空白并将其与给定字符串进行比较 */
  11. if(name == cookiePair[0].trim()) {
  12. // 解码cookie值并返回
  13. return decodeURIComponent(cookiePair[1]);
  14. }
  15. }
  16. // 如果未找到,则返回null
  17. return null;
  18. }
  19. document.write("url = " + getCookie("url") + "<br>"); // 输出:url = http://c.biancheng.net/
  20. document.write("course = " + getCookie("course") + "<br>"); // 输出:course = JavaScript
  21. document.write("title = " + getCookie("title"));

JS 修改或更新 Cookie 的值 

修改或更新 Cookie 值的唯一方法就是创建一个同名的 Cookie,来替换要修改的 Cookie。注意,若要修改的 Cookie 定义了 path 属性,在修改该属性时也要定义相同的 path 属性,否则会创建一个新的 Cookie。示例代码如下

  1. // 创建一个 Cookie
  2. document.cookie = "url=http://c.biancheng.net/; path=/; max-age=" + 30*24*60*60;
  3. // 修改这个 Cookie
  4. document.cookie = "url=http://c.biancheng.net/javascript/; path=/; max-age=" + 365*24*60*60;

JS 删除 Cookie 

删除 Cookie 与修改 Cookie 类似,只需要重新将 Cookie 的值设置为空,并将 expires 属性设置为一个过去的日期即可,如下例所示:

  1. // 创建一个 Cookie
  2. document.cookie = "url=http://c.biancheng.net/; path=/; max-age=" + 30*24*60*60;
  3. // 删除这个 Cookie
  4. var d = new Date();
  5. d.setTime(d.getTime()-1);
  6. var expireTime = d.toGMTString()
  7. var expires1 = ";expires="+expireTime;
  8. document.cookie = "url=http://c.biancheng.net/;"+expires1+";path=/"

另外,也可通过将 max-age 属性设置为 0 来删除 Cookie。 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/149639
推荐阅读
相关标签
  

闽ICP备14008679号