브라우징 컨텍스트 간의 양방향 통신을 채널 메시징이라고 합니다. 여러 출처 간의 통신에 유용합니다.
messageChannel을 생성하는 동안 내부적으로 2개의 포트를 생성하여 데이터를 보내고 다른 브라우징 컨텍스트로 전달합니다.
- postMessage() − 메시지 전송 채널 게시
- 시작() − 데이터를 보냅니다.
- 닫기() - 포트를 닫습니다.
이 시나리오에서는 한 iframe에서 다른 iframe으로 데이터를 보내고 있습니다. 여기서 우리는 함수에서 데이터를 호출하고 데이터를 DOM에 전달합니다.
var loadHandler = function(){
var mc, portMessageHandler;
mc = new MessageChannel();
window.parent.postMessage('documentAHasLoaded','https://foo.example',[mc.port2]);
portMessageHandler = function(portMsgEvent){
alert( portMsgEvent.data );
}
mc.port1.addEventListener('message', portMessageHandler, false);
mc.port1.start();
}
window.addEventListener('DOMContentLoaded', loadHandler, false);