iframe子页面与父页面的通信早就被研究透彻了,之前一直没有用到这个内容所以也没有去研究,今天突然遇到一道题目,所以稍微试了一下,跨域通信使用了来自腾讯团队给出的messenger.js,源码也很简单值的一看,官方给出的demo很全面,此处我只是给出了一个简单的例子。
域内通信
父页面
iframe子页面与父页面通信(同域) iframe子页面与父页面同域通信
调用子页面child1.html中的sayHello()函数:
子页面
iframe子页面与父页面通信(同域) 调用父页面iframeCommunication1.html中的sayHello()函数:
跨域通信
对于IE8+及现代浏览器,跨域通信主要使用了html5给出的postMessage API来实现域间通信。postMessage的功能是允许程序员跨域在两个窗口/frames间发送数据信息。基本上,它就像是跨域的AJAX,但不是浏览器跟服务器之间交互,而是在两个客户端之间通信。
对于旧版浏览器,messenger.js使用了navigator对象在父窗口和iframe之间是共享的特性,在navigator对象上注册消息回调函数实现信息传递及共享。
下面给出一个很简单的例子:
父页面
iframe子页面与父页面通信(跨域) iframe子页面与父页面跨域通信
向子页面child2.html发送信息:
获取信息:










