javascript postMessage not working

时光总嘲笑我的痴心妄想 提交于 2019-12-03 02:31:02

The second parameter of your postMessage must be an url like http://localhost

If you are not dealing with different origins, entering location.origin as the targetOrigin will work.

top.postMessage('hello', location.origin);

you can also send the message to any window use top.postMessage('hello', "*");

Html 1:

<iframe src="IFRAME_URL"></iframe>
<script>
window.addEventListener( "message",
  function (e) { 
        alert(e.data);
  },
  false);
</script>

html 2:

<html>
<head></head>
<body>
    <script>
        top.postMessage('hello', '*');
    </script>
</body>

I'm not sure of the security concerns, but typically, I just grab the parent window location like this:

var url = (window.location != window.parent.location) ? document.referrer: document.location;
top.postMessage('message', url);
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!