您现在的位置是:网站首页> 编程资料编程资料
详解使用postMessage解决iframe跨域通信问题关于iframe跨域使用postMessage的实现使用postMessage让 iframe自适应高度的方法示例
2021-08-31
953人已围观
简介 这篇文章主要介绍了详解使用postMessage解决iframe跨域通信问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
这周碰到一个让人头疼的需求:要在我的web项目中嵌入另一个第三方web项目。第一时间想到的就是用iframe了,但问题来了,我和第三方web项目是有交互的,这就违反同源策略了,处理跨域问题是最让人头疼的事之一。
需求是这样的,在我的页面点击一些按钮,要实时反馈到iframe子页面,子页面再进行响应。
当时脑子里第一时间想到的解决方案是:用NGINX把两个项目代理到同一域名下。但这样似乎有点小题大做了,有没有更方便快捷的方法呢?
在window对象下有个postMessage方法,是专门用来解决跨域通信问题的。
关于postMessage的详细介绍请戳这里,不过MDN的文档太详细了,导致有些同学看完还是一脸懵逼,下面我们就来看看怎么用postMessage实现iframe跨域通信,当你会用了之后再回去看文档,感觉是完全不同的。
首先我们模拟场景,假设有两个不同源的页面,iframePage.html是index.html的子页面:
this is index
this is iframePage
现在这两个iframe是无法通信,因为它们是不同源的(假设存在跨域问题),这时候就要用到postMessage了。
我们先试着从父页面向子页面发送一条消息:
// idnex.html //获取iframe元素 iFrame = document.getElementById('myframe') //iframe加载完毕后再发送消息,否则子页面接收不到message iFrame.onload = function(){ //iframe加载完立即发送一条消息 iFrame.contentWindow.postMessage('MessageFromIndex1','*'); }我们知道postMessage是挂载在window对象上的,所以等iframe加载完毕后,用iFrame.contentWindow获取到iframe的window对象,然后调用postMessage方法,相当于给子页面发送了一条消息。
postMessage方法第一个参数是要发送的数据,可以是任何原始类型的数据。
Gecko 6.0 (Firefox 6.0 / Thunderbird 6.0 / SeaMonkey 2.3)之前,第一个参数必须是一个字符串。
postMessage方法第二个参数可以设置要发送到哪个url,如果当前子页面的url和设置的不一致,则会发送失败,我们设置为*,代表所有url都允许发送。
postMessage方法还有第三个参数,属于高级用法,这里不做讨论,可以稍后去MDN了解。
消息发送到iframePage.html,我们来接收message:
// iframePage.html //回调函数 function receiveMessageFromIndex ( event ) { console.log( 'receiveMessageFromIndex', event ) } //监听message事件 window.addEventListener("message", receiveMessageFromIndex, false); 我们只需要在子页面监听message事件,并且设置好回调函数即可,来看看打印出来的event:

event对象中的data属性存放着我们从父页面传过来的数据,就这么简单!
让我们再试试从子页面发送数据给父页面:
// iframePage.html //给父页面发送消息,data为对象 parent.postMessage( {msg: 'MessageFromIframePage'}, '*'); 父页面接收数据:
//index.html //回调函数 function receiveMessageFromIframePage (event) { console.log('receiveMessageFromIframePage', event) } //监听message事件 window.addEventListener("message", receiveMessageFromIframePage, false); 我看看到,的确可以传输不同的数据,此时data为一个对象:

大家可以到postMessage-demo把代码clone下来运行试试看。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关内容
- 跨域修改iframe页面内容详解关于iframe跨域使用postMessage的实现HTML5 window/iframe跨域传递消息 API介绍Iframe 高度自适应(兼容IE/Firefox、同域/跨域)
- html如何对span设置宽度在Firefox或IE中span无法确定宽度的解决方案设置span宽度高度的方法CSS中将Span标签设置为固定宽度的方法span无法设置宽度的问题的解决方法设置span 宽度的完美解决方案兼容IE和FF的单行溢出文本显示省略号-CSS教程-网页制作-网页教学网
- 关于iframe跨域使用postMessage的实现HTML5 window/iframe跨域传递消息 API介绍Iframe 高度自适应(兼容IE/Firefox、同域/跨域)
- 使用canvas生成含有微信头像的邀请海报没有微信头像问题微信小程序之html5 canvas绘图并保存到系统相册详解html5 canvas 微信海报分享(个人爬坑)HTML5+Canvas实现飞机加速减速特效源码html5 canvas合成海报所遇问题及解决方案总结HTML5 Canvas微信运动折线图特效源码HTML5+canvas实现微信朋友圈发红包照片特效源码
- Html5与App的通讯方式详解详解HTML5通讯录获取指定多个人的信息 html5跨域通讯之postMessage的用法总结
- html+js 实现markdown编辑器效果HTML5高仿微信聊天、微信聊天表情|对话框|编辑器功能html5使用Drag事件编辑器拖拽上传图片的示例代码基于HTML5新特性Mutation Observer实现编辑器的撤销和回退操作
- 高清屏下canvas重置尺寸引发的问题的解决浅析canvas元素的html尺寸和css尺寸对元素视觉的影响html5中canvas学习笔记1-画板的尺寸与实际显示尺寸
- HTML table 表格边框的实现思路html中table表格的内容水平和垂直居中显示详解HTML中table表格的frame和rules属性Div+CSS对HTML的table表格定位用法实例深入解析HTML的table表格标签与相关的换行问题html 隐藏div HTML里隐藏表格TABLE或者DIV内容的css样式HTML table表格边框的控制详细说明HTML的dl、dt、dd标记制作表格对决Table制作表
- Html5自定义字体解决方法html5 canvas绘制网络字体的常用方法使用HTML5 Canvas API控制字体的显示与渲染的方法HTML5时代CSS设置漂亮字体取代图片
- webView加载html图片遇到的问题解决HTML5 图片预加载的示例代码利用简洁的图片预加载组件提升html5移动页面的用户体验 html5实现的页面滚动图片动画加载特效源码HTML5实现的图片无限加载的瀑布流效果另带边框圆角阴影基于HTML代码实现图片碎片化加载功能
