• sessionStorage 的数据会在同一网站的多个标签页之间共享吗?这取决于标签页如何打开


    一直以来,我所以为的 sessionStorage 的生命周期是这样的:在 sessionStorage 中存储的数据会在当前浏览器的同一网站的多个标签页中共享,并在此网站的最后一个标签页被关闭后清除。注意:这是错误的。

    我之所以会这么认为,是因为我写代码的时候,sessionStorage 给我的表现就是这样的。

    假设我们有一个 index.html

    <!-- 使用一个新标签页打开自身,并设置一个 sessionStorage -->
    <a href="index.html" target="_blank" onclick="sessionStorage.setItem('j', 's')">
      open myself
    </a>

    接下来:

    1. 在浏览器中打开这个 index.html,我们称之为标签页 A。注意:需要用 http 协议打开!例如 http://localhost/index.html
    2. 点击页面上的链接,此时会弹出来标签页 B。
    3. 在标签页 B 中打开控制台并执行 sessionStorage.getItem('j')

    控制台会输出 's',这说明标签页 A 和 B 共享了 sessionStorage 中的数据;接下来,先关闭这两个标签页,然后再打开一个标签页 C,再读取一下 j 的值,得到的是 null

    这看起来跟本文一开始的说法是一致的,但今天我遇到了一个奇怪的事情……

    我们给上面的步骤添加第四步:

    1. 在浏览器中打开这个 index.html,我们称之为标签页 A。注意:需要用 http 协议打开!例如 http://localhost/index.html
    2. 点击页面上的链接,此时会弹出来标签页 B。
    3. 在标签页 B 中打开控制台并执行 sessionStorage.getItem('j'),得到 's'
    4. 新建一个新标签页 D,然后在地址栏内输入 http://localhost/index.html 打开同样的页面, 然后执行 sessionStorage.getItem('j') 。

    按照我的预期,标签页 D 得到的应该还是 's',毕竟我认为 sessionStorage 的数据是在同一网站的多个标签页之间共享的。但是我错了,得到的结果是 null

    发生了什么?为什么标签页 B 中得到的是 's',为什么标签页 D 中却是 null

    细心的同学可能已经发现了,标签页 B 和标签页 D 之间唯一的不同就是它们被打开的方式:标签页 B 是通过在标签页 A 中点击链接打开的,但标签页 D 是在浏览器地址栏输入地址打开的。

    我赶紧上 MDN 查了一下,上面是这么说的:

    ...data stored in sessionStorage gets cleared when the page session ends...Opening a page in a new tab or window will cause a new session to be initiated, which differs from how session cookies work.

    所以现在我明白了:通过点击链接(或者用了 window.open)打开的新标签页之间是属于同一个 session 的,但新开一个标签页总是会初始化一个新的 session,即使网站是一样的,它们也不属于同一个 session。

  • 相关阅读:
    linux系统--磁盘管理命令(二)
    linux系统--磁盘管理命令(一)
    linux系统--用户和用户组
    linux4.10.8 内核移植(四)---字符设备驱动_led驱动程序
    linux4.10.8 内核移植(三)---裁剪内核
    linux4.10.8 内核移植(二)---初步裁剪、分区修改和文件系统
    Linux 4.10.8 根文件系统制作(三)---制作yaffs文件系统
    Kotlin的面向对象入门
    Python 中的GIL
    python 虚拟环境的 安装与 使用 和修改为豆瓣源
  • 原文地址:https://www.cnblogs.com/as007012/p/9860605.html
Copyright © 2020-2023  润新知