vue通过BroadcastChannel实现不同标签页直接传递消息

crossTagMsg.js

复制代码
const channel = new BroadcastChannel('demo');

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);
    };
}

A.vue发送消息页面

复制代码
import {listenMsg} from '@/utils/crossTagMsg'

function update(){
	sendMsg("更新", "dddd")
}

B.vue监听消息页面

复制代码
import {listenMsg} from '@/utils/crossTagMsg'

//监听消息
const cancelListen = listenMsg((msgInfo) => {
  console.log('监听到了更新', msgInfo)
})
//组件销毁时移除监听
onBeforeUnmount(cancelListen);
相关推荐
巴巴博一2 分钟前
UniApp 纯前端实现企业级购物车:Vuex + Storage 多用户状态管理闭环方案
前端·vue.js·uni-app·状态模式
未来之窗软件服务2 分钟前
自己写算法(十)js加密UUID保护解密——东方仙盟化神期
java·javascript·算法·代码加密·东方仙盟算法
浮桥4 分钟前
uniapp页面列表列表请求hook记录
前端·javascript·uni-app
bluceli6 分钟前
前端微前端架构实战指南:构建可扩展的大型应用架构
前端
进击的尘埃6 分钟前
给 PR 接一个 LLM 自动 Review:GitHub Actions 落地踩坑全记录
javascript
阿懂在掘金6 分钟前
Vue Asyncx 库三周年,回顾起源时的三十行代码
前端·typescript·开源
一只不会编程的猫7 分钟前
Echart 3D环形图
前端·javascript·3d
脸大是真的好~7 分钟前
黑马AI+前端教程 01-HTML-Trae-F12-live Server-标签-块级和内联元素-图片格式-路径
前端·html
前端付豪8 分钟前
拍照识题 OCR
前端·后端·python
专业流量卡8 分钟前
龙虾写useEffect源码第二天
前端