当前位置: 首页 > news >正文

iframe通信,window.postMessage父子项目数据通信

父 => 子

父项目

 <iframe:src="cockpitUrl"id="cockpitIframe"@load="handleLoad" ></iframe>// 向子系统传递数据(注意要再iframe的load中注册,保证iframe已经加载完成,这样子项目才能监听到)
const handleLoad = () => {const iframe: any = document.getElementById("cockpitIframe");if (iframe.contentWindow) {iframe.contentWindow.postMessage({type: "on-cockpit",data: {userInfo: JSON.parse(JSON.stringify("obj要传递的数据")),},},"*");}
};

子项目

  window.addEventListener("message", (event) => {const data = event.data;if (data.type) {case "on-cockpit"://这里就可以拿到父项目传递的数据break;}}});

子 => 父

子项目

 window.parent.postMessage({type: "skip-cockpit",payload: JSON.parse(JSON.stringify("要传递给父项目的数据")),},"*");

父项目

 window.addEventListener("message", (event) => {const data = event.data;if (data.type) {switch (data.type) {case "skip-cockpit"://这里就可以拿到子项目传递过来的数据break;}}});

如果你在子项目中使用 window.addEventListener(‘message’, …) 来监听消息,但收到的 event.data 类型是 “webpackWarnings”,这可能是因为你的监听器在Webpack开发服务器的环境下也会接收到一些Webpack相关的警告信息

window.addEventListener('message', event => {// 确保消息来源可信// 例如可以检查消息的来源是否是你所期望的主框架的URL// 然后再处理接收到的数据if (event.origin !== 'http://expected-source.com') {return; // 消息来源不是你所期望的,忽略}// 处理收到的数据const receivedData = event.data;
});
http://www.lryc.cn/news/294327.html

相关文章:

  • ES6中新增Array.from()函数的用法详解
  • Camera2+OpenGL ES+MediaCodec+AudioRecord实现录制音视频写入H264 SEI数据
  • C语言笔试题之反转链表(头插法)
  • WEB3:互联网发展的新时代
  • c语言:贪吃蛇的实现
  • 第5课 使用FFmpeg将rtmp流再转推到rtmp服务器
  • Vue中v-if和v-show区别
  • LabVIEW与EtherCAT实现风洞安全联锁及状态监测
  • PostgreSQL的wal文件回收问题
  • java-JUC并发编程学习笔记05(尚硅谷)
  • vulhub中spring的CVE-2022-22947漏洞复现
  • 网络原理TCP/IP(1)
  • EasyExcel使用,实体导入导出
  • 让IIS支持SSE (Server Sent Events)
  • 新手从零开始学习数学建模论文写作(美赛论文临时抱佛脚篇)
  • k8s存储之PV、PVC
  • go-基于逃逸分析来提升性能程序
  • [软件工具]文档页数统计工具软件pdf统计页数word统计页数ppt统计页数图文打印店快速报价工具
  • linux编译ffmpeg动态库
  • Unity3d Cinemachine篇(完)— TargetGroup
  • 事件驱动架构:使用Flask实现MinIO事件通知Webhooks
  • 力扣面试150 只出现一次的数字Ⅱ 哈希 统计数位 DFA有穷自动机
  • R语言学习case10:ggplot基础画图Parallel Coordinate Plot 平行坐标图
  • Easy Excel动态表头的实现
  • kvm qemu 优化 windows 虚拟机速度
  • 银行数据仓库体系实践(18)--数据应用之信用风险建模
  • 每日一练 | 华为认证真题练习Day179
  • [ubuntu]add-apt-repository 添加以及移除
  • PySpark(二)RDD基础、RDD常见算子
  • 修改MFC图标