某天,领导提了一个需求,主页面里面嵌套iframe,父子页面双向发送消息。然后我就提了一个方案: postMessage
知识理论准备:
postMessage方法允许来自不同源的脚本采用异步方式进行有限的通信,可以实现跨文本档、多窗口、跨域消息传递。
语法:
otherWindow.postMessage(message, targetOrigin, [transfer]);
- otherWindow:其他窗口的引用,如 iframe的contentWindow、执行window.open返回的窗口对象、或者是命名过或数值索引的window.frames。
- message:将要发送到其他window的数据。
- targetOrigin:指定那些窗口能接收到消息事件,其值可以是字符串 “*” 表示无限制,或者是一个URI。
- transfer:是一串和message同时传递的Transferable对象,这些对象的所有权将被转移给消息的接收方,而发送方将不再保留所有权。
postMessage方法被调用时,会在所有页面脚本执行完毕之后像目标窗口派发一个 MessageEvent 消息,该MessageEvent消息有四个属性需要注意:
- type:表示该message的类型
- data:为 postMessage 的第一个参数
- origin:表示调用postMessage方法窗口的源
- source:记录调用postMessage方法的窗口对象
操作流程如下:
1.准备两个页面
- http://a.com/main.html 主页面
- http://b.com/iframepage.html 嵌套页面
main.html
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>iframe+postMessage 跨域通信 主页面</title> </head> <body> <h1>主页面</h1> <iframe id="child" src="http://b.com/iframepage.html"></iframe> <div> <h2>主页面接收消息区域</h2> <span id="message"></span> </div> </body> </html>
iframepage.html
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>iframe+postMessage跨域通信 子页面</title> </head> <body> <h2>子页面</h2> <div> <h3>接收消息区域</h3> <span id="message"></span> </div> </body> </html>
2、父向子发送消息
main.html
<script> window.onload = function(){ document.getElementById('child') .contentWindow.postMessage("主页面消息", "http://b.com/iframepage.html") } </script>
注意:
一定是页面加载完成后在发送消息,否则会因为 iframe 未加载完成报错。
Failed to execute ‘postMessage’ on ‘DOMWindow’
子页面接收消息:
iframepage.html
<script> window.addEventListener('message',function(event){ console.log(event); document.getElementById('message').innerHTML = "收到" + event.origin + "消息:" + event.data; }, false); </script>
此时可看到页面中,iframe的子页面中打印了
收到http://a.com消息:主页面消息`
以及控制台打印了MessageEvent对象。
3、子向父发送消息
子页收到消息后回复父页面
iframepage.html
<script> window.addEventListener('message',function(event){ console.log(event); document.getElementById('message').innerHTML = "收到" + event.origin + "消息:" + event.data; top.postMessage("子页面消息收到", 'http://a.com/main.html') }, false); </script>
父页面收到消息并显示:
window.addEventListener('message', function(event){ document.getElementById('message').innerHTML = "收到" + event.origin + "消息:" + event.data; }, false);
4、完整代码
main.html
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>iframe+postMessage 跨域通信 主页面</title> </head> <body> <h1>主页面</h1> <iframe id="child" src="http://b.com/iframepage.html"></iframe> <div> <h2>主页面接收消息区域</h2> <span id="message"></span> </div> </body> <script> window.onload = function(){ document.getElementById('child') .contentWindow.postMessage("主页面消息", "http://b.com/iframepage.html") } window.addEventListener('message', function(event){ document.getElementById('message').innerHTML = "收到" + event.origin + "消息:" + event.data; }, false); </script> </html>
iframepage.html
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>iframe+postMessage跨域通信 子页面</title> </head> <body> <h2>子页面</h2> <div> <h3>接收消息区域</h3> <span id="message"></span> </div> </body> <script> window.addEventListener('message',function(event){ if(window.parent !== event.source){return} console.log(event); document.getElementById('message').innerHTML = "收到" + event.origin + "消息:" + event.data; top.postMessage("子页面消息收到", 'http://a.com/main.html') }, false); </script> </html>
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“html父子页面iframe双向发消息的实现示例”评论...
更新日志
2024年05月13日
2024年05月13日
- 哥斯拉大战金刚2:帝国崛起 Godzilla x Kong: The New Empire
- 千织角色攻略心得分享,千织角色武器攻略
- 《原神》茸茸城堡大喵险第四关攻略
- 《原神》4.5那芙万配队攻略 那芙万输出手法与出装推荐
- 任天堂社长:Switch继任者的宣布可能会影响公司销量
- 星穹铁道梦境护照16收集位置 那是一个最好的时代贴纸收集位置大全
- 金海心.-.[金海心].专辑.(APE+CUE)
- 破碎之地新手能力选择推荐 能力效果分析
- 《小猫咪大城市》Steam”好评如潮”!好评率高达95%
- 星穹铁道梦境护照17收集位置 晨星与昏星贴纸收集位置大全
- 苏曼《佳人曲HQ》头版限量[低速原抓WAV+CUE]
- 最终幻想14 x 最终幻想XI联动任务星歌异闻再临
- 华纳兄弟:《自杀小队》失败 导致损失2亿美元收入
- 孙露《同名专辑HQ》头版限量编号[低速原抓WAV+CUE]
- 崩坏星穹铁道2.2他落下的羽毛怎么做 他落下的羽毛隐藏成就攻略