Vue跨标签页数据通信

跨标签页数据通信

在同一浏览器项目地址处于不同的标签页中,建立两个页面间的数据通信,即:B页面新增/修改数据;A页面表格自动更新数据

跨标签页通信常见方案:

BroadCast Channel (广播频道)

Service Worker

LocalStorage Window.onstorage监听

Shared Worker 定时器轮询

IndexedDB 定时器轮询

cookie 定时器轮询

Websocket

Window.open、Window.postmesAge

方案样例

BroadCast Channel(广播频道): 需要保证每个标签页使用同一个频道,比如下方的'sync-update'

创建文件:crossTagMsg.js(表示跨标签页的消息)

javascript 复制代码
const channel = new BroadcastChannel('sync-update');
export function sendMsg(type, content) {
channel.postMessage({
type,
content,
});
}
export function listenMsg(callback) {
const handler = (e) => {
callback && callback(e.data);
} 
channel.addEventListener('message', handler);
return () => {
channel.removeEventListener('message', handler);
};
}

新增/编辑页面add/edit.vue

javascript 复制代码
// emp.value 这是个代理对象,无法被克隆,需要把它变成普通对象
// sendMsg( 'add-emp', { ...emp.value } );
  	// 我这里用的对象替代了数组
sendMsg("update-emp", { ...this.emp })

列表页面

javascript 复制代码
import { listenMsg } from "./utils/crossTagMsg"
var vm = null  //媒介
const unListen = listenMsg((info) => {
  if (info.type === "add-emp") {
    vm.emp.value.unshift(info.conten)
  } else if (info.type === "update-emp") {
  	// 我这里用的对象替代了数组
    vm.emp = info.content

	// -------------使用list对象-------------
	//const i = emps.value.findIndex((emp) => emp.id === info.content.id)
    //if (i >= 0) {
      // vue3的写法
      //emps.value[i] = info.content
      // vue2写法, 或者用$set
      // emps.value[i] = emps.value.splice(i, 1, info.content)
    //}
  }
})

data(){
   emp: { id: "sync-update", value1: "原值", value2: "内容" },
}

created() {
    let _this = this
    vm = _this  //this指向赋值
},
onUnmounted(unListen);
相关推荐
moMo8 小时前
# JavaScript 的“等等我”:聊聊同步与异步
javascript
KaMeidebaby8 小时前
卡梅德生物技术快报|重组蛋白的表达和纯化:工艺调试全记录:大肠杆菌体系重组蛋白的表达和纯化参数标定(肠激酶轻链案例)
前端·人工智能·算法·数据挖掘·数据分析
Cobyte8 小时前
19.Vue Vapor 的实现原理原来这么简单
前端·javascript·vue.js
JackieDYH8 小时前
uniapp vue3 常用的生命周期和作用使用时机
javascript·vue.js·uni-app
郝学胜-神的一滴8 小时前
中级OpenGL教程 009:用环境光告别模型死黑
前端·c++·unity·godot·图形渲染·opengl·unreal
半岛盒子9 小时前
AI Coding方案与事件流(前端)
前端
星栈9 小时前
Makepad 应用如何读文件、调接口、保存数据
前端·rust
qq_466302459 小时前
office 2021 下载安装激活
前端
新新学长搞科研9 小时前
【广东省博促会主办】2026年第七届先进材料与智能制造国际学术会议(ICAMIM 2026)
大数据·前端·数据库·人工智能·物联网
铁皮饭盒9 小时前
用bunjs代码讲解XSS/CSRF/SQL注入/DDos等10种前后端安全防护
前端·后端