window.onstorage监听localStorage变化

切记,需要以下2点:

1、 localStorage发生变化,初次设置值不生效。

2、不同的浏览器tab,本页面不生效。比如打开了a.html和b.html,a.html设置了一个值,b.html去修改值,事件才会生效

3、在中间件下测试,比如tomcat,nginx

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script>
        function save() {
            localStorage.setItem("change-event", new Date().getTime())
        }
        function change() {
            localStorage.setItem("change-event",new Date().getTime())
        }	
		
        window.onstorage = function (e) {
            console.log(e)
            console.log(`The ${e.key} key has been changed from ${e.oldValue} to ${e.newValue}.`);
        };		
    </script>
</head>

<body>
    <button onclick="save()">localstorge click</button>
	<br>
	<iframe src="./b.html">
	</iframe>
	
</body>

</html>

 解决同一个页面下的瓶颈,使用iframe

通知仅在不同的上下文中接收。这意味着不同的页面,不要期望在同一页面中不同对象的上下文中使用本地存储进行通信。一些浏览器会考虑将“同一页面”应用于当前页面内的不同 iframe。Chrome 和 Firefox 的行为似乎符合预期,您可以在同一页面中的不同 iframe 之间进行通信,但为​​了更好地使用发布消息,请尽可能使用。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值