由于同源策略的限制,Javascript存在跨域通信的问题,典型的跨域问题有iframe与父级的通信等。
常规的几种解决方法:
(1) document.domain+iframe;
(2) 动态创建script;
(3) iframe+location.hash;
(4) flash。
这里不细说这几种方法,记录的是HTML5的window.postMessage。
postMessage兼容IE8+、Firefox、Opera、Safari、Chrome。
需要两个异域的服务器来做测试,当然也可以用本地和线上服务器作为两个异域的服务器。
假如使用phonegap开发,就可以将请求文件安装在客户端,然后动态请求服务器的数据处理,获得并显示数据。这样就可以用任意Web开发语言及方法来开发phonegap App所需的后台。
1. postMessage的用法
postMessage是HTML5为解决js跨域问题而引入的新的API,允许多个iframe/window跨域通信。
假设有结构如下:
- test.html<section id="wrapper"> <header>
- <h1>postMessage (跨域)</h1> </header>
- <article> <form>
- <p> <label for="message">给iframe发一个信息:
- </label> <input type="text" name="message" value="son" id="message"/>
- <input type="submit"/> </p>
- </form> <h4>目标iframe传来的信息:</h4>
- <p id="test">暂无信息</p> <iframe id="iframe"
- src="http://xiebiji.com/works/postmessage/iframe.html"> </iframe>
- </article>
</section>
iframe.html









