页面通信方式——跨文档消息传递XDM

XDM:cross-document messaging:指来自不同域的页面间传递消息

功能:XDM核心是postMessage()方法,向包含在当前页面的<iframe>元素/当前页面弹出的窗口传递数据。

核心:postMessage(消息,消息接收方的域)

第一个参数为: 消息字符串,若要传入结构化数据,通过json.stringify()把数据串化成字符串形式。
第二个参数: 对保障安全通信有重要作用,可以防止浏览器把消息发送到不安全的地方
var iframeWindow = document.getElementById("iframeID").contentWindow; 
//所有支持XDM的浏览器也支持iframe的contentWindow属性
iframeWindow.postMessage("消息","http://www.xxx.com");
接收到XDM消息时,会触发window的message事件,该事件以异步形式触发,所以从发送消息到接收消息会有时间延迟。触发message事件后,传递给onmessage事件处理程序的event对象包含:
1. data: 传入postMessage()的第一个参数,即消息。若处理的是使用json.stringify()后的结构化数据字符串,通过json.parse()方法把字符串解析回结构化数据。
2. origin :发送消息的文档所在域
3. source:发送消息的文档的window对象代理,用于调用postMessage方法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

明致成

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值