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

相关推荐
前端fighter6 分钟前
js基本数据新增的Symbol到底是啥呢?
前端·javascript·面试
流着口水看上帝15 分钟前
JavaScript完整原型链
开发语言·javascript·原型模式
guokanglun18 分钟前
JavaScript数据类型判断之Object.prototype.toString.call() 的详解
开发语言·javascript·原型模式
川石教育24 分钟前
Vue前端开发子组件向父组件传参
前端·vue.js·前端开发·vue前端开发·vue组件传参
Embrace92444 分钟前
为什么 Vue2会出现数据更新视图不更新 Vue3不会出现
javascript·vue.js·ecmascript
qq_415628171 小时前
bpmn.js显示流程图
javascript·vue.js·流程图
GISer_Jing1 小时前
Vue前端进阶面试题目(二)
前端·vue.js·面试
乐闻x1 小时前
Pinia 实战教程:构建高效的 Vue 3 状态管理系统
前端·javascript·vue.js
程序员学姐2 小时前
基于SpringBoot+Vue的高校社团管理系统
java·开发语言·vue.js·spring boot·后端·mysql·spring
橘子味小白菜2 小时前
el-table的树形结构后端返回的id没有唯一键怎么办
前端·vue.js