Can I do synchronous cross-domain communicating with window.postMessage?

空扰寡人 提交于 2019-12-04 07:45:33
suknic

The postMessage() function is asynchronous, meaning it will return immediately. So you can not do synchronous communication with it.

In your example, the posted message will vanish in the void, because there is no listener for the message event at the time the postMessage() function is executed.

If you would load the iframe first and call postMessage() afterwards, then there could be an timing issue, maybe. (From my experience there is none, the parent code is always execute first, but I am not sure about this point.)

Below is my solution for the problem of not knowing exactly when the iframe will be ready.

In the parent window:

  1. Load the iframe (this is asynchronous, too)
  2. Set up message listener
  3. Post message to the iframe (just trying here)
  4. Wait for more messages to come

In the iframe:

  1. Set up message listener
  2. Post message to the parent window (just trying here)
  3. Wait for more messages to come

Whoever receives the first message from the other side then starts the real communication.

In my experience, the message from the parent to the iframe always gets lost, so the communication starts when the parent receives the message from the iframe. But in this setup it is not important which one starts first.

To send the first message to the iframe from the parent window, you can only do it once the iframe is loaded and before that you can not even send the message from child to parent. So in order to do so provide a onload handler for the iframe so that you can use the postmessge(). Consider the following code for the same.

ifrm.setAttribute('src','www.yoururl.com'));
document.body.appendChild(ifrm);
ifrm.onload = function() {
   this.contentWindow.postMessage(dataObject,'targetWindow');
}
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!