JavaScript通过更改Web Storage实现页面间通信
Posted fengma
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript通过更改Web Storage实现页面间通信相关的知识,希望对你有一定的参考价值。
这个API的作用是,使得网页可以在浏览器端储存数据。它分成两类:sessionStorage和localStorage。
sessionStorage保存的数据用于浏览器的一次会话,当会话结束(通常是该窗口关闭),数据被清空;localStorage保存的数据长期存在,下一次访问该网站的时候,网页可以直接读取以前保存的数据。除了保存期限的长短不同,这两个对象的属性和方法完全一样。
它们很像cookie机制的强化版,能够动用大得多的存储空间。目前,每个域名的存储上限视浏览器而定,Chrome是2.5MB,Firefox和Opera是5MB,IE是10MB。其中,Firefox的存储空间由一级域名决定,而其他浏览器没有这个限制。也就是说,在Firefox中,a.example.com
和b.example.com
共享5MB的存储空间。另外,与Cookie一样,它们也受同域限制。某个网页存入的数据,只有同域下的网页才能读取。
好了,简介完了,下面上干货:
// 写入数据 sessionStorage.setItem("key","value"); localStorage.setItem("key","value"); // 读取数据 var valueSession = sessionStorage.getItem("key"); var valueLocal = localStorage.getItem("key"); // 删除数据 sessionStorage.removeItem(\'key\'); localStorage.removeItem(\'key\'); // 清除所有数据 sessionStorage.clear(); localStorage.clear();
这是基本的操作方法。
下面讲如何页面间通信:
1. 在页面A中写监听:
function onStorageChange(e) { console.log(e); } window.addEventListener("storage",onStorageChange);
2. 页面B中进行任何数据操作都会触发所有同源页面的storage事件。(值得特别注意的是,该事件不在导致数据变化的当前页面触发。如果浏览器同时打开一个域名下面的多个页面,当其中的一个页面改变sessionStorage或localStorage的数据时,其他所有页面的storage事件会被触发,而原始页面并不触发storage事件。可以通过这种机制,实现多个窗口之间的通信。所有浏览器之中,只有IE浏览器除外,它会在所有页面触发storage事件。)
流程图片:
a:
b:
c:
以上是关于JavaScript通过更改Web Storage实现页面间通信的主要内容,如果未能解决你的问题,请参考以下文章
javaScript中的Cookie和web Storage(LocalStorage-SessionStorage)详解
firebase.storage() 不是 JavaScript 中的函数