利用localStorage事件来跨标签页共享sessionStorage

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了利用localStorage事件来跨标签页共享sessionStorage相关的知识,希望对你有一定的参考价值。

//干货 利用localStorage事件来跨标签页共享sessionStorage
//因为cookie保存字节数量有限,很多童鞋考虑用html5 storage来保存临时数据,Sessionstorage就比较适合来保存临时数据了。
//但有个问题呵:Sessionstorage:不支持跨标签页共享数据,就是说Sessionstorage只在同一个页面内有效,即使用一域名,新打开一个tab窗口,也是不能共享Sessionstorage的。
//那么有没有办法呢,那是有的....
//原理是运用了EventListener的特性
//同源的网页A和B,A页面监听了storage事件,B页面修改localStorage时,A页面才会触发该事件;而A页面做出修改,同样B页面触发了事件

// 下面 EventListener 没对ie作支持,童鞋自行补充
shareSessionStorage: function(){
    if(!window.webConfig.useStorage || !window.sessionStorage){
        return;
    }
//    console.log("useStorage:", webConfig.useStorage);
    // 该事件是核心
    var handel = function(event){
  //      console.log("event==>", event.key);
        if(event.key ==getSessionStorage) {
            var userData = window.sessionStorage.getItem("UserData");
            var sessionData = {
                "UserData": userData
            };

            // 已存在的标签页会收到这个事件
            window.localStorage.setItem(sessionStorage, JSON.stringify(sessionData));
            window.localStorage.removeItem(sessionStorage);
        } else if(event.key ==sessionStorage) {
            // 新开启的标签页会收到这个事件
            var data =JSON.parse(event.newValue);   // console.log("event==>", event.newValue);
            for (var key in data) {
                window.sessionStorage.setItem(key, data[key]);
            }
        }
    };
    window.removeEventListener("storage", handel);
    window.addEventListener("storage", handel);

    // 这个调用能触发目标Global.js storage事件,从而达到共享数据的目的
    window.localStorage.setItem(getSessionStorage, Date.now());
},

 

以上是关于利用localStorage事件来跨标签页共享sessionStorage的主要内容,如果未能解决你的问题,请参考以下文章

解决sessionStorage不能跨标签页共享

localStoragesessionStorage的区别

SessionStorage && localStorage && cookie

localStorage 与 sessionStorage

如何实现浏览器内多个标签页之间的通信?

如何实现浏览器内多个标签页之间的通信?