news 2026/6/10 18:07:52

前端跨标签页通信方案(上)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
前端跨标签页通信方案(上)

前情

平时开发很少有接触到有什么需求需要实现跨标签页通信,但最近因为一些变故,不得不重新开始找工作了,其中就有面试官问到一道题,跨标签页怎么实现数据通信,我当时只答出二种,面试完后特意重新查资料,因此有些文章

localStorage / sessionStorage

利用localStorage的存储事件实现通信,当一个标签页修改localStorage时,其他同源标签页会触发storage事件

关键代码如下:

标签页1

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<title>page0-localStorage</title>

</head>

<body>

<button id="setCacheBtn">设置本地缓存</button>

<script>

document.getElementById('setCacheBtn').addEventListener('click', () => {

localStorage.setItem('message', JSON.stringify({

type: 'greeting',

// 这里为了保证通信每次生效,每次都设置不同的值

content: 'Hello from page0.html' + Date.now()

}));

});

</script>

</body>

</html>

标签页2

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<title>page1-localStorage</title>

</head>

<body>

<script>

window.addEventListener('storage', (e) => {

if (e.key === 'message') {

const data = JSON.parse(e.newValue);

console.log('Received:page1.html', data);

}

});

</script>

</body>

</html>

动图演示:

20250923_193504

提醒:

同源标签才有效

设置不同的本地存储值才有效,如果设置的是同一个缓存值是不会生效的

兼容性非常nice,可以大胆使用了,国内一些浏览器从can i use查不到,但兼容性是没啥问题的

sessionStorage仅在同一标签页的不同 iframe 间有效,不适用于不同标签页

image

BroadcastChannel

专门用于同源标签页通信的 API,创建一个频道后,所有加入该频道的页面都能收到消息

关键代码如下:

标签页1

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<title>BroadcastChannel0</title>

</head>

<body>

<h1>BroadcastChannel0</h1>

<button id="communication">BroadcastChannel0.html 发送消息</button>

<script>

// 所有页面都创建相同名称的频道

const channel = new BroadcastChannel('my_channel');

// 发送消息

document.getElementById('communication').addEventListener('click', () => {

channel.postMessage({ type: 'update', data: 'new content from BroadcastChannel0.html' });

});

</script>

</body>

</html>

标签页2

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<title>BroadcastChannel1</title>

</head>

<body>

<h1>BroadcastChannel1</h1>

<script>

// 所有页面都创建相同名称的频道

const channel = new BroadcastChannel('my_channel');

// 接收消息

channel.onmessage = (e) => {

console.log('Received:BroadcastChannel1.html', e.data);

};

</script>

</body>

</html>

演示动图如下:

20250923_200047

提醒:

要通信的标签记得都初始化BroadcastChannel,一定记得使用相同的名称

查询来看除IE外可以大但使用了

image 1

小结

这二种是我面试的时候答出来的,第二种我只是模糊记得跟面试官模棱二可的说了说,面试馆给了正面的回应,呵呵……,此文暂时写这么多,下篇继续探索其它方式……

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 10:38:42

18、容器使用指南:LXD 与 Docker 入门

容器使用指南:LXD 与 Docker 入门 1. 容器简介 容器是一项古老的技术,早期以 chroot 和 FreeBSD Jails 的形式存在。随着 Docker 的兴起,容器技术得到了广泛的应用和普及。Ubuntu 在 15.04 版本中推出了新工具 LXD。 容器是一种轻量级的虚拟环境,用于容纳一个或一组进程…

作者头像 李华
网站建设 2026/6/9 3:14:02

19、容器管理与网络配置:LXD与Docker的深度解析

容器管理与网络配置:LXD与Docker的深度解析 在容器技术的领域中,LXD和Docker是两个备受关注的工具。LXD提供了强大的容器管理功能,而Docker则专注于应用容器化。下面将详细介绍LXD的高级管理选项、资源限制设置、网络配置以及Docker的安装过程。 LXD容器的高级管理选项 L…

作者头像 李华
网站建设 2026/6/9 15:06:00

25、Git 远程仓库同步、更新、克隆及 GitLab 安装与用户管理全攻略

Git 远程仓库同步、更新、克隆及 GitLab 安装与用户管理全攻略 1. 与远程服务器同步仓库 在进行本地代码管理时,我们常常需要将本地仓库与远程服务器同步。这里以 GitHub 为例,介绍如何设置远程仓库并同步本地代码。 1.1 准备工作 你需要一个 GitHub 账户。若没有,可注册…

作者头像 李华
网站建设 2026/6/10 17:06:38

SpringBoot联合PostGIS实现在线地图行政区划离线存储的实践探索

目录 前言 一、行政区划物理表设计 1、物理表字段设计 2、表结构脚本 二、行政区划在线API 1、请求参数简介 2、响应参数简介 三、Java后台数据获取及空间存储 1、API服务调用 2、递归获取数据 四、成果展示 1、PostGIS数据查询 2、WebGIS可视化 五、总结 前言 在…

作者头像 李华
网站建设 2026/6/10 17:04:41

为什么OAuth2与SSO经常混为一谈?

简介最近在工作中遇到了一个问题&#xff0c;在实现OAuth2的过程中&#xff0c;发现公司的实际落地与理论不完全相同。故此复习一下。What is OAuth2?OAuth2(OAuth2.0)是一个开放标准的授权框架&#xff0c;用于第三方应用(客户端)在取得用户(资源所有者)的授权下&#xff0c;…

作者头像 李华