使用postmessage刷新iframe的父文档

时间:2010-09-26 23:47:01

标签: iframe cross-domain parent

我有一个greasemonkey脚本,它打开一个iframe,其中包含来自不同子域的表单作为父页面。

我希望在表单提交后iframe刷新时刷新父页面

我在iframe刷新时可以执行一个函数,但是我无法使该函数影响父文档。

我明白这是由于浏览器安全模型,我一直在阅读使用postMessage在两个窗口之间进行通信,但我似乎无法弄清楚如何使用它向父级发送重新加载调用。

任何关于如何做到这一点的建议都会非常有帮助

感谢

1 个答案:

答案 0 :(得分:50)

使用:

window.parent.postMessage('Hello Parent Frame!', '*');

注意'*'表示“任何来源”。如果可能,您应该将其替换为目标原点。

在您的父框架中,您需要:

window.addEventListener('message', receiveMessage, false);

function receiveMessage(evt)
{
  if (evt.origin === 'http://my.iframe.org')
  {
    alert("got message: "+evt.data);
  }
}

将“my.iframe.org”替换为您的iFrame的来源。 (您可以跳过原点验证,只需要非常小心对所获得的数据执行的操作)。