前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >H5 storage事件

H5 storage事件

作者头像
用户9184480
发布2024-12-17 10:04:44
发布2024-12-17 10:04:44
5000
代码可运行
举报
文章被收录于专栏:云计算linux云计算linux
运行总次数:0
代码可运行
代码语言:javascript
代码运行次数:0
复制
<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title></title>
  </head>
  <body>
    <div id="header">
</div>
      <div class="demo">
          <p><label for="data">Your test data:</label> <input type="text" name="data" value="" placeholder="change me" id="data" /><input type="button" value="保存localStorage数据" id="save"/></p>
          <p id="fromEvent">Waiting for data via <code>storage</code> event...</p>
      </div>
</div>
<script type="text/javascript">
var addEvent = (function() {
    if (document.addEventListener) {
        return function(el, type, fn) {
            if (el.length) {
                for (var i = 0; i < el.length; i++) {
                    addEvent(el[i], type, fn);
                }
            } else {
                el.addEventListener(type, fn, false);
            }
        };
    } else {
        return function(el, type, fn) {
            if (el.length) {
                for (var i = 0; i < el.length; i++) {
                    addEvent(el[i], type, fn);
                }
            } else {
                el.attachEvent('on' + type,
                function() {
                    return fn.call(el, window.event);
                });
            }
        };
    }
})();


var dataInput = document.getElementById('data'),
    output = document.getElementById('fromEvent'),
save = document.getElementById('save');
addEvent(window, 'storage', function (event) {
  if (event.key == 'storage-event-test') {
      output.innerHTML ="key:"+event.key+" ---- old:"+event.oldValue+" ---- new:"+ event.newValue;
  }
});
addEvent(save, 'click', function () {
  localStorage.setItem('storage-event-test', dataInput.value);
});
</script>
  </body>
</html>

HTML5提供一个storage事件,当setItem()、removeItem()或者clear()方法被调用,并且数据真的发生了改变时,storage事件就会被触发。注意,只有数据真的发生了变化,才会触发storage事件。也就是说,如果当前的存储区域是空的,调用clear()是不会触发事件的。或者通过setItem()来设置一个与现有值相同的值,storage事件也是不会被触发的torage事件的

Event对象包含如下属性:

 storageArea,表示存储类型(localstorage或sessionstorage);

 key,发生改变的项的key

 oldValue,发生改变的项的原值

 newValue,发生改变的项的新值

 url, key改变发生的URL

H5 storage事件_数据
H5 storage事件_数据

必须将文件上传到Web服务器上(或者localhost),才支持storage事件。

不同浏览器对storage事件的支持情况不同。经测试,Internet Explorer 9可以在当前页面中接收到storage事件,而在firefox和chrome中,必须同时打开两个窗口浏览【例10-5】,在其中一个窗口中单击按钮,在另一个窗口会接收到storage事件。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-03-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档