一起源码网

  • www.171739.xyz
  • 全球最大的互联网技术和资源下载平台
搜索
猜你喜欢
查看: 5712|回复: 1
打印 上一主题 下一主题

iframe子、父页面域内及跨域通信实例

[复制链接]

0

主题

0

帖子

1万

积分

钻石会员

Rank: 8Rank: 8

积分
17424
QQ
跳转到指定楼层
楼主
发表于 2020-4-28 20:30 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
iframe子页面与父页面的通信早就被研究透彻了,之前一直没有用到这个内容所以也没有去研究,今天突然遇到一道题目,所以稍微试了一下,跨域通信使用了来自腾讯团队给出的messenger.js,源码也很简单值的一看,官方给出的demo很全面,此处我只是给出了一个简单的例子。

域内通信

父页面

<!DOCTYPE html><html><head><title>iframe子页面与父页面通信(同域)</title><meta charset="utf-8"><script type="text/javascript">
    function sayHello(){
        alert("iframeCommunication1.html");
    }    function say(){
        child1.window.sayHello();
        child1.window.document.getElementById("button_c").value = "the call is complete";
    }</script></head><body><h1>iframe子页面与父页面同域通信</h1>调用子页面child1.html中的sayHello()函数:<input type="button" id="button_p" name="hello" value="call" onclick="say()"><br><br><iframe src="child1.html" id="child1"></iframe></body></html>

子页面

<!DOCTYPE html><html><head><title>iframe子页面与父页面通信(同域)</title><meta charset="utf-8"><script type="text/javascript">
    function sayHello(){
        alert("child.html");
    }    function say(){
        parent.sayHello();
        parent.window.document.getElementById("button_p").value = "the call is complete";
    }</script></head><body><p>调用父页面iframeCommunication1.html中的sayHello()函数:</p><input type="button" id="button_c" name="hello" value="call" onclick="say()"></body></html>

跨域通信

对于IE8+及现代浏览器,跨域通信主要使用了html5给出的postMessage API来实现域间通信。postMessage的功能是允许程序员跨域在两个窗口/frames间发送数据信息。基本上,它就像是跨域的AJAX,但不是浏览器跟服务器之间交互,而是在两个客户端之间通信。
对于旧版浏览器,messenger.js使用了navigator对象在父窗口和iframe之间是共享的特性,在navigator对象上注册消息回调函数实现信息传递及共享。
下面给出一个很简单的例子:

父页面

<!DOCTYPE html><html><head><title>iframe子页面与父页面通信(跨域)</title><meta charset="utf-8"><script src="js/messenger.js"></script></head><body><h1>iframe子页面与父页面跨域通信</h1>向子页面child2.html发送信息:<input type="button" id="button_p" value="call" onclick="sendMessage('child2')"><br><br>获取信息:<pre id="output"></pre><br><br><iframe src="child2.html" id="child2" style="width: 50%; height: 300px;"></iframe><script type="text/javascript">
    function say(msg){
        var output = document.getElementById("output");
        output.innerHTML = msg;
        console.log("in parent");
    }    var messenger = new Messenger('parent', 'CROSS_DOMAIN_COMMUNICATION'),
        child2 = document.getElementById('child2');
    messenger.listen(say);
    messenger.addTarget(child2.contentWindow, 'child2'); // 添加一个消息对象
    function sendMessage(name) {
        messenger.targets[name].send('message from parent');
    }</script></body></html>

子页面

<!DOCTYPE html><html><head><title>iframe子页面与父页面通信(跨域)</title><meta charset="utf-8"><script src="js/messenger.js"></script></head><body><h1>child2</h1>向父页面iframeCommunication2.html发送信息:<br><input type="button" id="button_p" value="call" onclick="sendMessage('parent')"><br><br>获取信息:<pre id="output"></pre><br><br><script type="text/javascript">
    function say(msg){
        var output = document.getElementById("output");
        output.innerHTML = msg;
        console.log('in child2');
    }    var messenger = new Messenger('child2', 'CROSS_DOMAIN_COMMUNICATION');
    messenger.listen(say);
    messenger.addTarget(window.parent, 'parent'); // 添加一个消息对象
    // messenger.addTarget(window.parent.frames[1], 'parent'); // 与父窗口的其他子窗口通信
    function sendMessage(name) {
        messenger.targets[name].send('message from child2');
    }</script></body></html>

参考

[1] js之iframe子页面与父页面通信
[2] iframe跨域通信的通用解决方案-第二弹!(终极解决方案) | Tencent AlloyTeam
[3] Messengerjs项目主页i

分享到:  QQ好友和群QQ好友和群
收藏收藏
回复

使用道具 举报

0

主题

14

帖子

44

积分

新手上路

Rank: 1

积分
44
沙发
发表于 2022-9-30 21:01 | 只看该作者
波士顿机器人代码开源
回复

使用道具 举报

一起源码让程序更轻更快

www.171739.xyz

工作时间 周一至周六 8:00-17:30

侵权处理

客服QQ点击咨询

关注抖音号

定期抽VIP

Copyright © 2016-2021 https://www.171739.xyz/ 滇ICP备13200218号

快速回复 返回顶部 返回列表