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 年)
  • 必须保证 pathdomain 与当初设置时完全一致,否则删不掉
  • 推荐写法:document.cookie = "username=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/";

注意事项和替代方案

原生 Cookie 操作繁琐、易出错,且有大小限制(单个约 4KB,总数量也有限)。现代项目中建议:

  • 优先使用 localStoragesessionStorage 存储非敏感前端数据
  • 涉及登录态、权限等关键信息,仍应由后端设 Cookie(含 HttpOnlySecure),前端只负责触发登录/登出逻辑
  • 若必须 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使用