之前都是使用 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
。
因为便利出来的 name
和 value
是带有空格的。
所以需要再处理一下,可以封装成一个方法:
代码语言: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的方法