[Web数据控制]浏览器中cookie、localStorage和sessionStorage

前言

最近在跟随公司的前辈大哥们做一个全栈项目,让我负责前端页面数据的存取控制。想要做好网站的数据存取控制,就需要明白好客户端的浏览器各个域的作用机制。

区别

共享性

cookie和localStorage都是跟随同一个网址的存储空间。在同一个网址下,所有的标签页之间共享cookie和localStorage。

而sessionStorage是当前标签页下有效。同一个网站不同的标签页,sessionStorage一般是不共享的。只有同源窗口(协议、域名、端口一致,注意是这里说的是窗口,不是标签页和网址),不同页面可以共享sessionStorage的值。意思就是,如果我新的一页是通过 window.open 方法或者是通过链接打开时,新页面会复制前一个页面的sessionStorage。

保存时长

localStorage:永久有效,除非script代码清除或者删除浏览器缓存

sessionStorage:当前会话内有效,当窗口关闭时(刷新可以视为重启页面,也有关闭页面的行为)清除里面的数据。

cookie:由开发者编辑代码时设置,大多开发框架默认行为是设置成永久有效,同localStorage一样。也可以由开发者设置过期时长。

最后一个重要的差别是,cookie中的内容会跟随在每一个请求头中,而localStorage和sessionStorage不会。

相关推荐
TimelessHaze9 分钟前
拆解字节面试题:async/await 到底是什么?底层实现 + 最佳实践全解析
前端·javascript·trae
执键行天涯38 分钟前
从双重检查锁定的设计意图、锁的作用、第一次检查提升性能的原理三个角度,详细拆解单例模式的逻辑
java·前端·github
青青子衿越41 分钟前
微信小程序web-view嵌套H5,小程序与H5通信
前端·微信小程序·小程序
OpenTiny社区1 小时前
TinyEngine 2.8版本正式发布:AI能力、区块管理、Docker部署一键强化,迈向智能时代!
前端·vue.js·低代码
qfZYG1 小时前
Trae 编辑器在 Python 环境缺少 Pylance,怎么解决
前端·vue.js·编辑器
bug爱好者1 小时前
Vue3 基于Element Plus 的el-input,封装一个数字输入框组件
前端·javascript
Silence_xl1 小时前
RACSignal实现原理
前端
柯南二号1 小时前
【大前端】实现一个前端埋点SDK,并封装成NPM包
前端·arcgis·npm
dangkei1 小时前
【Wrangler(Cloudflare 的官方 CLI)和 npm/npx 的区别一次讲清】
前端·jvm·npm
乔公子搬砖1 小时前
小程序开发提效:npm支持、Vant Weapp组件库与API Promise化(八)
前端·javascript·微信小程序·js·promise·vagrant·事件绑定