加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 资源网站 > 资源 > 正文

html – localStorage eventHandler不会被调用

发布时间:2020-12-14 19:34:27 所属栏目:资源 来源:网络整理
导读:这是我的代码: script type="text/javascript" function getLocalStorage() { try { if (!! window.localStorage) return window.localStorage; } catch(e) { return undefined; } } function getAddEventListener() { try { if( !! window.addEventListene
这是我的代码:
<script type="text/javascript">
    function getLocalStorage() {
        try {
            if (!! window.localStorage) return window.localStorage;
        } catch(e) {
            return undefined;
        }
    }

    function getAddEventListener() {
        try {
            if( !! window.addEventListener ) return window.addEventListener;
        } catch(e) {
            return undefined;
        }
    }

    function eventHandler(e) {
        alert("here we are = " + e.storageArea.traveler);
    }       

    function testStorage() {    
        var db = getLocalStorage();
        var addEL = getAddEventListener();

        if(addEL) {
          addEL('storage',eventHandler,false);
        } else {
            alert('This browser does not support event listeners');
        }

        db.setItem('traveler','Bill');
        db.setItem('destination','Ventura');
        db.setItem('transportation','Airplane');

        document.getElementById('results').innerHTML = db.getItem('destination');
    }   
</script>

</head>

<body onload="testStorage();">
  <div id="results"> </div>
</body>

</html>

它成功地在本地存储中插入项目并在’results’-element中显示结果,但eventHandler不起作用.我刷新浏览器窗口,看不到任何警报消息.为什么?

解决方法

因为存储事件不适用于同一窗口/选项卡.它们仅针对使用相同localStorage的其他窗口/选项卡触发.尝试打开两个单独的选项卡,并在一个插入一些数据到localStorage.

这是一个类似的question,解释了localStorage活动的工作原理.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读