LocalStorage、SessionStorage、Cookie 的共享差异

最近在做一个Pixel的项目,在这个过程中,很多地方都用到了LocalStorageSessionStorageCookie 这三个特性来做本地存储,以往的使用场景都没有此次复杂,所以在使用过程中,也发现了许多和以往认知不同的地方,这些差异其实在官方的文档中都有提及,只是过往均是使用一些常用的点,所以也未曾注意。
常见的比如存储情况等特性,这里不再赘述,仅对共享情况的差异进行对比,这个是我以往较少用到的,此次也发现了诸多的差异之处。这里先放上简单的结论表供参考。

LocalStorage SessionStorage Cookie
同源共享 仅当前标签页且同源共享 同一个主域名且同协议下可以共享

LocalStorage

首先来说LocalStorage,其在同源的情况下是共享的,注意这里是同源。这个其实和平时的认知并没有什么差异,主要是要注意同源和同域名的区别即可。

例子:

dev1.test.comdev2.test.com 下是违反同源策略的,是不能共享的,这个和Cookie是有差异的。

SessionStorage

SessionStorage我原来的认知是错误较多的!在原来的使用中,深度使用较少,基本是以使用其关闭浏览器即清除的特性巨多,会惯性的认为,其他特性与LocalStorage相差无几。

但在使用的过程中发现,虽然其在同源条件下是共享的,但是其条件限制较多,需要同源且同标签页。下面是官方文档的一段特性描述。

  • 页面会话在浏览器打开期间一直保持,并且重新加载或恢复页面仍会保持原来的页面会话。
  • 在新标签或窗口打开一个页面时会复制顶级浏览会话的上下文作为新会话的上下文,这点和 session cookie 的运行方式不同。
  • 打开多个相同的 URL 的 Tabs 页面,会创建各自的 sessionStorage。
  • 关闭对应浏览器标签或窗口,会清除对应的 sessionStorage。

例子:

  1. dev1.test.com/a.html 页面打开 dev1.test.com/b.html ,注意要在当前页面打开,这时候SessionStorage是共享的,如果是新开标签页或者窗口,那么SessionStorage会被清空,这符合官方文档的描述,但因为LocalStorage的思维惯性,我一直以为它在不同标签页间也会共享。

  2. dev1.test.com/a.html 页面打开 dev2.test.com/b.html ,这时候由于非同源,无论是当前页面打开还是新开,都无法共享SessionStorage,这里是符合以往的认知。

Cookie的特性基本是符合以往认知的,因为之前做一些主域名相同但子域名不同的同步问题上使用较多,其在同一个主域名 间可以跨标签页/窗口 共享,且可以根据使用场景来决定存储时效,但这里要注意一点的是,同一域名下,不同的协议是不可以共享的。 在我的Pixel项目中,我基本是以短期Cookie配合持久存储的LocalStorage来同步本地信息。

例子:

dev1.test.com/a.html 页面写入Cookie,在 dev1.test.com/b.html 是可以获取到的,但如果想要在 dev2.test.com/b.html 中获取到,需要在设置的时候配置domin参数和path参数,比如document.cookie="a=1; domain=test.com; path=/;

相关推荐
hbrown3 分钟前
Flask+LayUI开发手记(十一):选项集合的数据库扩展类
前端·数据库·python·layui
猫头虎7 分钟前
什么是 npm、Yarn、pnpm? 有什么区别? 分别适应什么场景?
前端·python·scrapy·arcgis·npm·beautifulsoup·pip
迷曳16 分钟前
27、鸿蒙Harmony Next开发:ArkTS并发(Promise和async/await和多线程并发TaskPool和Worker的使用)
前端·华为·多线程·harmonyos
安心不心安1 小时前
React hooks——useReducer
前端·javascript·react.js
像风一样自由20201 小时前
原生前端JavaScript/CSS与现代框架(Vue、React)的联系与区别(详细版)
前端·javascript·css
啃火龙果的兔子1 小时前
react19+nextjs+antd切换主题颜色
前端·javascript·react.js
_pengliang1 小时前
小程序按住说话
开发语言·javascript·小程序
布兰妮甜1 小时前
创建游戏或互动体验:从概念到实现的完整指南
javascript·游戏开发·游戏ai·互动体验·用户输入处理
paid槮1 小时前
HTML5如何创建容器
前端·html·html5
小飞悟2 小时前
一打开文章就弹登录框?我忍不了了!
前端·设计模式