javascript的Cookie如何操作_怎样读写和删除Cookie?
发布时间 - 2025-12-31 00:00:00 点击率:次JavaScript操作Cookie通过document.cookie实现,读取返回分号分隔字符串,写入需按name=value; expires=...格式赋值,删除需覆盖并设过期时间,且path/domain必须匹配原设置。
JavaScript 操作 Cookie 主要是通过 document.cookie 这个属性来完成的,它看起来像一个变量,但实际是**读写接口**:读取时返回当前域名下所有可用 Cookie 的字符串(用分号分隔),写入时则需按特定格式赋值才能设置或更新。
如何写入(设置)Cookie
设置 Cookie 就是给 document.cookie 赋值一个符合格式的字符串。基本结构为:
name=value; expires=GMTString; path=/; domain=.example.com; secure; HttpOnly(JS不可读)
其中只有 name=value 是必需的,其它都是可选属性。常用操作示例:
立即学习“Java免费学习笔记(深入)”;
- 简单设置:
document.cookie = "username=john";(会话级 Cookie,关闭浏览器即失效) - 带过期时间(7天后):
document.cookie = "token=abc123; expires=" + new Date(Date.now() + 7*24*60*60*1000).toUTCString(); - 指定路径和域名(让子路径也能访问):
document.cookie = "theme=dark; path=/; domain=.site.com"; - 安全标记(仅 HTTPS 传输):
document.cookie = "sessionid=xyz; secure; SameSite=Strict";
如何读取 Cookie
document.cookie 读取返回的是一个类似 "a=1; b=2; c=3" 的字符串,没有内置解析方法,需要手动处理:
- 用
split('; ')拆成键值对数组 - 再对每个项用
split('=')分离 key 和 value - 注意空格和 URL 编码(中文或特殊字符需用
encodeURIComponent/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
Cookie 本身不能直接“删除”,只能通过覆盖的方式让它立即过期:
- 把
expires设为过去的时间(如 1970 年) - 必须保证
path和domain与当初设置时完全一致,否则删不掉 - 推荐写法:
document.cookie = "username=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/";

注意事项和替代方案
原生 Cookie 操作繁琐、易出错,且有大小限制(单个约 4KB,总数量也有限)。现代项目中建议:
- 优先使用
localStorage或sessionStorage存储非敏感前端数据 - 涉及登录态、权限等关键信息,仍应由后端设 Cookie(含
HttpOnly和Secure),前端只负责触发登录/登出逻辑 - 若必须 JS 操作 Cookie,可引入轻量库如 js-cookie 简化流程
基本上就这些。不复杂但容易忽略 path/domain 匹配和编码问题,写的时候多检查两遍就行。
# javascript
# java
# js
# 前端
# cookie
# 编码
# 浏览器
# session
# 后端
# ai
# 键值对
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何基于PHP生成高效IDC网络公司建站源码?
如何确认建站备案号应放置的具体位置?
绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信
如何正确下载安装西数主机建站助手?
Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】
详解Android图表 MPAndroidChart折线图
Laravel Admin后台管理框架推荐_Laravel快速开发后台工具
Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】
南京网站制作费用,南京远驱官方网站?
悟空识字如何进行跟读录音_悟空识字开启麦克风权限与录音
Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制
如何彻底删除建站之星生成的Banner?
用v-html解决Vue.js渲染中html标签不被解析的问题
Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
制作公司内部网站有哪些,内网如何建网站?
Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程
Laravel如何构建RESTful API_Laravel标准化API接口开发指南
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
Laravel如何创建自定义中间件?(Middleware代码示例)
Laravel如何使用Laravel Vite编译前端_Laravel10以上版本前端静态资源管理【教程】
如何在万网开始建站?分步指南解析
Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知
香港服务器租用费用高吗?如何避免常见误区?
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
如何用搬瓦工VPS快速搭建个人网站?
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
高性能网站服务器部署指南:稳定运行与安全配置优化方案
如何用JavaScript实现文本编辑器_光标和选区怎么处理
Angular 表单中正确绑定输入值以确保提交与验证正常工作
Laravel如何与Inertia.js和Vue/React构建现代单页应用
香港服务器网站卡顿?如何解决网络延迟与负载问题?
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法
做企业网站制作流程,企业网站制作基本流程有哪些?
Laravel如何处理文件下载请求?(Response示例)
Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件
Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控
无锡营销型网站制作公司,无锡网选车牌流程?
Laravel怎么解决跨域问题_Laravel配置CORS跨域访问
什么是JavaScript解构赋值_解构赋值有哪些实用技巧
Android使用GridView实现日历的简单功能
作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】
nginx修改上传文件大小限制的方法
如何快速搭建高效服务器建站系统?
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
Laravel如何生成API文档?(Swagger/OpenAPI教程)
Claude怎样写结构化提示词_Claude结构化提示词写法【教程】
Android GridView 滑动条设置一直显示状态(推荐)
Laravel Seeder填充数据教程_Laravel模型工厂Factory使用

