Localstorage 、sessionStorage 、cookie 的区别

共同点:

都是保存在浏览器端 、且同源的

区别:

1 、cookie 数据始终在同源的 http 请求中携带 (即使不需要), 即 cookie 在浏览器和服务 器间来回传递, 而 sessionStorage 和 localStorage 不会自动把数据发送给服务器, 仅在本 地保存 。cookie 数据还有路径 (path)的概念,可以限制 cookie 只属于某个路径下

2、存储大小限制也不同, cookie 数据不能超过 4K,同时因为每次 http 请求都会携带 cookie 、所以 cookie 只适合保存很小的数据,如会话标识 。sessionStorage 和 localStorage 虽然也有存储大小的限制, 但比 cookie 大得多,可以达到 5M 或更大

3、数据有效期不同, sessionStorage:仅在当前浏览器窗口关闭之前有效; localStorage: 始终有效, 窗口或浏览器关闭也一直保存, 因此用作持久数据;cookie:只在设置的 cookie过期时间之前有效, 即使窗口关闭或浏览器关闭

4、作用域不同, sessionStorage 不在不同的浏览器窗口中共享, 即使是同一个页面 ; localstorage 在所有同源窗口中都是共享的;cookie 也是在所有同源窗口中都是共享的

5 、web Storage 支持事件通知机制,可以将数据更新的通知发送给监听者

6、web Storage 的 api 接口使用更方便

相关推荐
等什么君!13 小时前
如何 正确使用 nrm 工具 管理镜像源
vue.js
warder13 小时前
字典状态管理:基于 Vue3 + Pinia 的工程化实践
vue.js
薛定谔的算法13 小时前
JavaScript栈的实现与应用:从基础到实战
前端·javascript·算法
魔云连洲14 小时前
React中的合成事件
前端·javascript·react.js
人工智能训练师14 小时前
在Ubuntu中如何使用PM2来运行一个编译好的Vue项目
linux·运维·服务器·vue.js·ubuntu·容器
浩星14 小时前
iframe引入界面有el-date-picker日期框,点击出现闪退问题处理
前端·vue.js·elementui
唐•苏凯15 小时前
ArcGIS Pro 遇到严重的应用程序错误而无法启动
开发语言·javascript·ecmascript
萌萌哒草头将军15 小时前
🚀🚀🚀 Oxc 恶意扩展警告;Rolldown 放弃 CJS 支持;Vite 发布两个漏洞补丁版本;Rslib v0.13 支持 ts-go
前端·javascript·vue.js
接着奏乐接着舞。15 小时前
3D地球可视化教程 - 第1篇:基础地球渲染系统
前端·javascript·vue.js·3d·three.js
薄雾晚晴15 小时前
Rspack 实战:用 SWC Loader 搞定 JS 兼容(支持 IE 11 + 现代浏览器,兼顾构建速度)
前端·vue.js