JavaScript获取cookie的方法

2023-08-25 12:46:30 浏览数 (2)

之前都是使用 php 对 cookie 进行操作,今天有个需求,需要用 js 获取网站的 cookie 。下面开始:

获取 cookie 存为数组:

代码语言:javascript复制
let cookieArr = document.cookie.split(";")

遍历数组,存为对象:

代码语言:javascript复制
let cookieObj = {};
for (let i = 0; i < cookieArr.length; i  ) {
  if (cookieArr[i]) {
    cookieSplit = cookieArr[i].split("=");
    cookieObj[cookieSplit[0]] = cookieSplit[1];
  }
}

不过这里需要注意一下,这样直接使用是不行的,会报错 undefined

因为便利出来的 namevalue 是带有空格的。

所以需要再处理一下,可以封装成一个方法:

代码语言:javascript复制
function getCookieObj () {//根据name获取cookie的值
  let cookieObj = {},
  cookieSplit = [],// 以分号(;)分组
  cookieArr = document.cookie.split(";"),;
  for (var i = 0; i < cookieArr.length; i  ) {
    if (cookieArr[i]) {
      cookieSplit = cookieArr[i].split("=");//以等号(=)分组
      cookieObj[cookieSplit[0].replace(/^s*|s*$/g, "")] = cookieSplit[1].replace(/^s*|s*$/g, "");//删除字符串两边的空格
    }
  }
  return cookieObj;
}

使用时直接调用即可:

代码语言:javascript复制
var c = getCookieObj(),
t = c.token;

未经允许不得转载:w3h5-Web前端开发资源网 » JavaScript获取cookie的方法

0 人点赞