iframe 通信不畅?可能是这些原因导致的

iframe 通信不畅?可能是这些原因导致的

iframe 作为一种常用的嵌入网页的方法,给我们开发者带来了很多便利,但同时也伴随着一些挑战,尤其是跨域通信的问题。在这篇文章中将探讨笔者遇到的一些无法通信的原因及其解决方法:

原因

  1. 父页面在 postMessage 的时候没有指定域:

根据 MDN 上的描述来看,otherWindow.postMessage(message, targetOrigin, [transfer]) 中的第二个参数 targetOrigin 的意义是指定哪些窗口能接收到消息事件,其值可以是字符串 *(表示无限制)或者一个 URI。在发送消息的时候,如果目标窗口的协议、主机地址或端口这三者的任意一项不匹配 targetOrigin 提供的值,那么消息就不会被发送;只有三者完全匹配,消息才会被发送。

通常我们并不会去传入第二个参数,因此在父页面和 iframe 不同源的情况下,无法通信。

js 复制代码
iframe.contentWindow?.postMessage({ type: 'data', data }, "*")
  1. iframe未就绪

如果你的主页面在 iframe 的内容完全加载之前就发送了消息,那么 iframe 可能会错过消息。你需要确保 iframe 已经完全加载后再发送消息。

js 复制代码
iframe.onload = () => {
  iframe.contentWindow?.postMessage({ type: 'data', data }, "*")
}

除此之外,这里还遇到了一个问题:在实际业务中,父页面按照上述代码发送数据,iframe 中则在 useEffect 中去监听 message 事件。结果发现父页面发送数据后了,message 事件还没设置上。浅浅推测下应该是 useEffect 的执行时机是在 dom 渲染结束之后的缘故。

我们可以采用主动获取 数据的方式。即 iframe 中也通过 window.parent.postMessage 告知父页面自己已经加载完毕了,父页面接收到这个信息后,再 postMessage 将数据传给 iframe。

  1. 协议不一致

在 Chrome 浏览器中,当你使用 https 页面去加载一个 http 的 iframe 的时候,会产生这样的报错:

这是浏览器自带的保护机制:

If your website delivers HTTPS pages, all active mixed content delivered via HTTP on these pages will be blocked by default. Consequently, your website may appear broken to users (if iframes or plugins don't load, etc.).

但是我们又没法去升级为 https 或者是 懒得去起代理服务。其实 Chrome 浏览器中提供了规避方法,只需要打开 chrome://flags/,进入 Chorme Experiments 设置页面,搜索 Insecure origins treated as secure,在里面输入我们想规避的url,再点击 Enable 启用功能即可。

本文介绍了 3 种导致 iframe 无法通信的常见原因并提出了有效的解决方案,相信各位读者遇到同样问题时,已经有了大概的解决办法。如果你有任何疑问或想法,欢迎在下方留言,我们一起探讨。感谢你的阅读,让我们期待下次相聚。

相关推荐
无巧不成书02181 小时前
Windows PowerShell执行策略详解:从npm报错到完美解决
前端·windows·npm·powershell执行策略·执行策略·npm.ps1·脚本报错
Z兽兽8 小时前
React@18+Vite项目配置env文件
前端·react.js·前端框架
SuniaWang8 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
A_nanda8 小时前
根据AI提示排查vue前端项目
前端·javascript·vue.js
happymaker06269 小时前
web前端学习日记——DAY05(定位、浮动、视频音频播放)
前端·学习·音视频
~无忧花开~9 小时前
React状态管理完全指南
开发语言·前端·javascript·react.js·前端框架
LegendNoTitle9 小时前
计算机三级等级考试 网络技术 选择题考点详细梳理
服务器·前端·经验分享·笔记·php
@大迁世界10 小时前
1.什么是 ReactJS?
前端·javascript·react.js·前端框架·ecmascript
BJ-Giser10 小时前
Cesium 基于EZ-Tree的植被效果
前端·可视化·cesium
王码码203511 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos