JavaScript操作Cookie通过document.cookie实现,读取返回分号分隔字符串,写入需按name=value; expires=...格式赋值,删除需覆盖并设过期时间,且path/domain必须匹配原设置。
JavaScript 操作 Cookie 主要是通过 document.cookie 这个属性来完成的,它看起来像一个变量,但实际是**读写接口**:读取时返
回当前域名下所有可用 Cookie 的字符串(用分号分隔),写入时则需按特定格式赋值才能设置或更新。
设置 Cookie 就是给 document.cookie 赋值一个符合格式的字符串。基本结构为:
name=value; expires=GMTString; path=/; domain=.example.com; secure; HttpOnly(JS不可读)
其中只有 name=value 是必需的,其它都是可选属性。常用操作示例:
document.cookie = "username=john";(会话级 Cookie,关闭浏览器即失效)document.cookie = "token=abc123; expires=" + new Date(Date.now() + 7*24*60*60*1000).toUTCString();
document.cookie = "theme=dark; path=/; domain=.site.com";
document.cookie = "sessionid=xyz; secure; SameSite=Strict";
document.cookie 读取返回的是一个类似 "a=1; b=2; c=3" 的字符串,没有内置解析方法,需要手动处理:
split('; ') 拆成键值对数组split('=') 分离 key 和 valueencodeURIComponent/decodeURIComponent)常用封装函数示例:
function getCookie(name) {
const cookies = document.cookie.split('; ');
for (let cookie of cookies) {
const [key, value] = cookie.split('=');
if (key === name) return decodeURIComponent(value);
}
return null;
}
Cookie 本身不能直接“删除”,只能通过覆盖的方式让它立即过期:
expires 设为过去的时间(如 1970 年)path 和 domain 与当初设置时完全一致,否则删不掉document.cookie = "username=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/";
原生 Cookie 操作繁琐、易出错,且有大小限制(单个约 4KB,总数量也有限)。现代项目中建议:
localStorage 或 sessionStorage 存储非敏感前端数据HttpOnly 和 Secure),前端只负责触发登录/登出逻辑基本上就这些。不复杂但容易忽略 path/domain 匹配和编码问题,写的时候多检查两遍就行。