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

相关推荐
记得早睡~2 小时前
leetcode51-N皇后
javascript·算法·leetcode·typescript
小小鸭程序员3 小时前
Vue组件化开发深度解析:Element UI与Ant Design Vue对比实践
java·vue.js·spring·ui·elementui
拉不动的猪3 小时前
vue自定义指令的几个注意点
前端·javascript·vue.js
yanyu-yaya3 小时前
react redux的学习,单个reducer
前端·javascript·react.js
陌路物是人非3 小时前
SpringBoot + Netty + Vue + WebSocket实现在线聊天
vue.js·spring boot·websocket·netty
拉不动的猪3 小时前
uniapp与React Native/vue 的简单对比
前端·vue.js·面试
加瓦点灯4 小时前
观察者模式:解耦对象间的依赖关系
开发语言·javascript·观察者模式
z_mazin4 小时前
Chrome开发者工具实战:调试三剑客
前端·javascript·chrome·网络爬虫
sen_shan5 小时前
Vue3+Vite+TypeScript+Element Plus开发-04.静态菜单设计
前端·javascript·typescript·vue3·element·element plus·vue 动态菜单
旧识君6 小时前
移动端1px终极解决方案:Sass混合宏工程化实践
开发语言·前端·javascript·前端框架·less·sass·scss