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.comb.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 中的函数

使用Web Storage模拟数据库

web storage 简单的网页留言版

存储桶文件更改后,如何清除静态 Cloud Storage 网站上的缓存?

web Storage