< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

需求:A页面中要嵌入一个iframe,这个iframe是B页面,此时A页面需要得到B页面的一些信息。

window.postMessage()

我们都知道浏览器的同源策略,即对于两个不同页面的脚本,只有当他们的页面具有相同的协议,端口号和主机(document.domain)时,两个脚本才能互相通信。
window.postMessage()方法规避了此限制,只要正确使用,这种方法就很安全。

重点:window.postMessage中的window始终是你要通信的目标页面的window。

用法

window.postMessage(message, targetPage, [transfer]);

  • message: 要传递的data
  • targetPage:你要发送信息的目标域名。*表示所有域名。
  • transfer:可选参数。是一串和message 同时传递的 Transferable 对象. 这些对象的所有权将被转移给消息的接收方,而发送一方将不再保有所有权。

案例

如果B页面需要向A页面传递message的话,在B页面使用window.postMessage方法向A页面传递message。

top.postMessage('This is page B!', pageA域名);

window.postMessage中的window始终是你要通信的目标页面的window,而这里A页面才是通信的目标页面,所以需要用top。

而在A页面需要监听"message"事件来获取B页面传递过来的message。

window.addEventListener('message', this.receiveMessage, false);
receiveMessage = (event) => {
    console.log(event.data);
}

event的属性有:

  • data:从页面B传过来的message
  • origin:页面B的origin
  • source:页面B的引用

如果A页面需要向B页面传递信息呢?

// Page A
// window为pageB页面的window,即iframe.contentWindow
document.getElementByID('iframe').contentWindow.postMessage(msg, pageB域名);
// Page B
window.addEventListener('message', this.receiveMessage, false);
receiveMessage = (event) => {
    console.log(event.data);
}

参考:https://blog.csdn.net/weixin_42420703/article/details/98229993

posted on   ╰透在骨子里的小傲娇  阅读(954)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示

目录