首页  >  文章  >  web前端  >  如何在浏览器选项卡之间共享 SessionStorage 值?

如何在浏览器选项卡之间共享 SessionStorage 值?

Barbara Streisand
Barbara Streisand原创
2024-10-21 15:25:30962浏览

How to Share SessionStorage Values Between Browser Tabs?

在浏览器选项卡之间共享 sessionStorage 值

会话存储存储可在单个浏览器选项卡中访问的数据,并在选项卡关闭时清除。但是,需要在某些应用程序的选项卡之间共享会话存储值。

要实现此目的,您可以利用 localStorage 及其“存储”事件侦听器。下面是一个允许跨选项卡传输 sessionStorage 的代码片段:

<code class="javascript">// transfers sessionStorage from one tab to another
var sessionStorage_transfer = function(event) {
  if(!event) { event = window.event; } // ie suq
  if(!event.newValue) return;          // do nothing if no value to work with
  if (event.key == 'getSessionStorage') {
    // another tab asked for the sessionStorage -> send it
    localStorage.setItem('sessionStorage', JSON.stringify(sessionStorage));
    // the other tab should now have it, so we're done with it.
    localStorage.removeItem('sessionStorage'); // <- could do short timeout as well.
  } else if (event.key == 'sessionStorage' &amp;&amp; !sessionStorage.length) {
    // another tab sent data <- get it
    var data = JSON.parse(event.newValue);
    for (var key in data) {
      sessionStorage.setItem(key, data[key]);
    }
  }
};

// listen for changes to localStorage
if(window.addEventListener) {
  window.addEventListener("storage", sessionStorage_transfer, false);
} else {
  window.attachEvent("onstorage", sessionStorage_transfer);
};


// Ask other tabs for session storage (this is ONLY to trigger event)
if (!sessionStorage.length) {
  localStorage.setItem('getSessionStorage', 'foobar');
  localStorage.removeItem('getSessionStorage', 'foobar');
};</code>

此代码应在所有选项卡上执行,并在其他脚本之前运行。

此方法允许跨选项卡传输 sessionStorage 值Chrome、Firefox、Safari、IE 11、IE 10 和 IE9 中的选项卡。在 IE8 中,您需要包含 JSON 填充程序以实现兼容性。

通过实现此代码,您可以在选项卡之间有效共享 sessionStorage 值,从而允许您的应用程序在同一浏览器会话中跨多个选项卡持久存储数据.

以上是如何在浏览器选项卡之间共享 SessionStorage 值?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn