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 接口使用更方便

相关推荐
To_OC1 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
如果超人不会飞5 小时前
脉络清晰的业务演进:TinyVue Timeline 时间线组件全方位实战指南
vue.js
如果超人不会飞5 小时前
从扁平到立体:掌握 TinyVue Grid 树形表格的高级实战指南
vue.js
To_OC7 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
用户2136610035728 小时前
Vue2组件化开发与父子通信
前端·vue.js
Momo__9 小时前
TypeScript satisfies 操作符——比 as 更安全的类型守门员
前端·typescript
用户2136610035729 小时前
Vue2事件系统与指令进阶
前端·vue.js
labixiong9 小时前
实现一个能跑的迷你版Promise(一)
前端·javascript·面试
逸铭12 小时前
Day 5:三栏布局——左账号 / 中聊天 / 右工具
vue.js·electron
用户17335980753713 小时前
Vue 3 SPA 首屏优化:从 3s 到 1.2s 的 5 个实践
前端·vue.js