浏览器两个 tab 都是同域,如何在一个tab 向另一个 tab 发消息

1. 使用 localStorage 事件

当修改 localStorage 时,会触发 storage 事件,其他同源页面可以监听该事件实现通信。

// Tab A 发送消息
localStorage.setItem('message', JSON.stringify({ content: 'Hello Tab B!' }));

// Tab B 接收消息
window.addEventListener('storage', (e) => {
  if (e.key === 'message') {
    const message = JSON.parse(e.newValue);
    console.log('Received:', message);
  }
});

特点

  • 只能传递字符串,需手动序列化/反序列化。

  • 当前 Tab 修改数据时不会触发自己的监听器,只有其他 Tab 会收到事件。

  • 受同源策略限制,仅限同域页面。

2 通过 window.postMessage(需窗口引用) 

如果两个 Tab 存在引用关系(如通过 window.open 打开),可直接通过 postMessage 通信。

// Tab A 打开 Tab B 并发送消息
const newTab = window.open('https://same-domain.com/tabB');
newTab.postMessage('Hello Tab B!', 'https://same-domain.com');

// Tab B 接收消息
window.addEventListener('message', (e) => {
  if (e.origin === 'https://same-domain.com') {
    console.log('Received:', e.data);
  }
});

特点

  • 需要直接引用目标窗口对象(如通过 window.open 或 window.opener)。

  • 适用于有明确父子关系的页面。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值