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

微前端传值

在微前端架构中,不同子应用之间通过 postMessage 进行通信是一种常见的做法。这种方式允许不同源的窗口之间进行安全的信息交换。

下面是如何使用 postMessage 在微前端环境中发送和接收消息的示例。

步骤 1: 发送消息

假设您有一个主应用(host app)和一个子应用(micro app)。子应用需要向主应用发送消息。

子应用代码示例:
// 子应用的 JavaScript 文件
function sendMessageToHostApp(message) {const hostWindow = window.parent; // 获取父窗口if (hostWindow && hostWindow.postMessage) {hostWindow.postMessage(message, '*'); // 发送到任何源}
}// 示例调用
sendMessageToHostApp({ type: 'GREETING', content: 'Hello from micro app!' });

步骤 2: 接收消息

接下来,您需要在主应用中监听 message 事件,以便能够接收到来自子应用的消息。

主应用代码示例:
// 主应用的 JavaScript 文件
window.addEventListener('message', function(event) {console.log('Received message:', event.data);// 检查消息来源是否可信if (event.origin !== 'http://your-sub-app-origin.com') {return;}// 处理消息switch (event.data.type) {case 'GREETING':console.log('Greeting received:', event.data.content);break;default:console.log('Unknown message type:', event.data.type);}
}, false);

注意事项:

  1. 消息来源验证:

    • 在接收到消息时,最好检查 event.origin 以确保消息来自预期的子应用。
    • 如果您的子应用部署在与主应用不同的域名上,您需要确保允许正确的源。
  2. 消息格式:

    • 使用结构化的消息格式(如 JSON 对象),以便于解析和处理。
  3. 错误处理:

    • 当发送或接收消息时,应考虑异常情况并进行适当的错误处理。
  4. 通信安全:

    • 在生产环境中,确保只信任来自安全源的消息。

示例完整代码

子应用(Micro App)
<!-- micro-app.html -->
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Micro App</title>
</head>
<body><h1>Micro App</h1><button onclick="sendMessage()">Send Message</button><script>function sendMessage() {const message = { type: 'GREETING', content: 'Hello from micro app!' };const hostWindow = window.parent;if (hostWindow && hostWindow.postMessage) {hostWindow.postMessage(message, '*'); // 发送到任何源}}</script>
</body>
</html>
主应用(Host App)
<!-- index.html -->
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Host App</title>
</head>
<body><h1>Host App</h1><iframe src="http://your-sub-app-origin.com/micro-app.html" width="300" height="200"></iframe><script>window.addEventListener('message', function(event) {console.log('Received message:', event.data);// 检查消息来源是否可信if (event.origin !== 'http://your-sub-app-origin.com') {return;}// 处理消息switch (event.data.type) {case 'GREETING':console.log('Greeting received:', event.data.content);break;default:console.log('Unknown message type:', event.data.type);}}, false);</script>
</body>
</html>

http://www.lryc.cn/news/429982.html

相关文章:

  • 《学会 SpringBoot · 依赖管理机制》
  • 全网行为管理软件有哪些?5款总有一款适合你的企业!
  • 以简单的例子从头开始建spring boot web多模块项目(二)-mybatis简单集成
  • Golang | Leetcode Golang题解之第354题俄罗斯套娃信封问题
  • jmeter中添加ip欺骗
  • WPF篇(19)-TabControl控件+TreeView树控件
  • appium下载及安装
  • XSS项目实战
  • SD-WAN降低网络运维难度的关键技术解析
  • 【算法基础实验】图论-最小生成树-Prim的即时实现
  • LLama 3 跨各种 GPU 类型的基准测试
  • FreeRTOS 快速入门(五)之信号量
  • centos 服务器之间实现免密登录
  • RabbitMq实现延迟队列功能
  • redis内存淘汰策略
  • 实时洞察应用健康:使用Spring Boot集成Prometheus和Grafana
  • 生信圆桌x生信豆芽菜:生物信息学新手的学习与成长平台
  • 创客匠人标杆对话(上):她如何通过“特长+赛道”实现财富升级
  • 最少钱学习并构建大模型ollama-llama3 8B
  • AVI视频损坏了怎么修复?轻松几步解决你的困扰
  • 【C++】map、set基本用法
  • 模型 闭环原理
  • 3007. 价值和小于等于 K 的最大数字(24.8.21)
  • 微服务 - 分布式锁的实现与处理策略
  • Catf1ag CTF Web(九)
  • QT QFileDialog 类
  • 了解 K-Means 聚类的工作原理(详细指南)
  • 预警先行,弯道哨兵让行车更安全
  • 预约咨询小程序搭建开发,uniapp前端,PHP语言开发
  • 极速文件预览!轻松部署 kkFileView 于 Docker 中!