html5 Postmessage解决跨域问题
2015-04-05 00:00
344 查看
在 Cross-document messaging 中使用 postMessage 和 onmessage
为了实现不同域之间的通信,需要在操作系统的 hosts 文件添加两个域名,进行模拟。清单 3. hosts 文件中添加两个不同的域名
127.0.0.1 parent.com 127.0.0.1 child.com
在父网页中通过 iframe 嵌入子页面,并在 JavaScript 代码中调用 postMessage 方法发送数据到子窗口。
清单 4. 父页面中嵌入子页面,调用 postMessage 方法发送数据
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Test Cross-domain communication using HTML5</title> <script type="text/JavaScript"> function sendIt(){ // 通过 postMessage 向子窗口发送数据 } </script> </head> <body> <!-- 通过 iframe 嵌入子页面 --> <iframe src="http://child.com:8080/TestHTML5/other-domain.html" id="otherPage"></iframe> <br/><br/> <input type="text" id="message"><input type="button" value="Send to child.com" onclick="sendIt()" /> </body> </html>
在子窗口中监听 onmessage 事件,并用 JavaScript 实现显示父窗口发送过来的数据。
清单 5. 子窗口中监听 onmessage 事件,显示父窗口发送来的数据
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Web page from child.com</title> <script type="text/JavaScript"> //event 参数中有 data 属性,就是父窗口发送过来的数据 window.addEventListener("message", function( event ) { // 把父窗口发送过来的数据显示在子窗口中 document.getElementById("content").innerHTML+=event.data+"<br/>"; }, false ); </script> </head> <body> Web page from http://child.com:8080 <div id="content"></div> </body> </html>
上班后,试试可行否。
相关文章推荐
- 使用HTML5中postMessage知识点解决Ajax中POST跨域问题
- html5中的postMessage解决跨域问题
- html5 postMessage解决iframe跨协议跨域通信问题
- [转]html5: postMessage解决跨域和跨页面通信的问题
- [Widget] HTML5解决跨域问题
- 使用HTML5中postMessage实现Ajax中的POST跨域问题
- html5 postMessage解决跨域、跨窗口消息传递
- 使用HTML5中postMessage实现Ajax中的POST跨域问题
- html5 postMessage解决跨域、跨窗口消息传递
- HTML5中Access-Control-Allow-Origin解决跨域问题
- HTML5 postMessage解决跨域、跨iframe窗口消息传递
- HTML5解决跨域问题
- #HTML5 & JS TIPS# 合法解决纯JS+HTML5前端简单跨域与复杂跨域问题
- HTML5中Access-Control-Allow-Origin解决跨域问题
- html5 postMessage解决跨域、跨窗口消息传递[转载]
- html5 postMessage解决跨域、跨窗口消息传递
- html5 postMessage解决跨域、跨窗口消息传递
- 【转】HTML5解决跨域问题
- 使用HTML5 跨域共享特性解决AJAX跨域数据同步问题
- html5 postMessage解决跨域、跨窗口消息传递