HTML5新特性之跨文档消息传输详解
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了HTML5新特性之跨文档消息传输详解,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2202字,纯文字阅读大概需要4分钟。
内容图文
![HTML5新特性之跨文档消息传输详解](/upload/InfoBanner/zyjiaocheng/389/df938652bb1d405c9d4807a3c8afb974.jpg)
1、同域限制
所谓“同域限制”是指,出于http://www.gxlcms.com/wiki/397.html" target="_blank">安全考虑,浏览器只允许脚本与同样协议、同样域名、同样端口的地址进行通信。
2、window.postMessage方法
浏览器限制不同窗口(包括iFrame窗口)之间的通信,除非两个窗口装载的是同一个域名下的网页。window.postMessage方法就是为了解决这个问题而特定的API,可以让不同域名的窗口互相通信。
postMessage方法的格式如下:
targetWindow.postMessage(message, targetURL[, transferObject]);
上面代码的targetWindow是指向目标窗口的变量,message是要发送的消息,targetURL是指定目标窗口的网址,不符合该网址就不发送信息,transferObject则是跟随信息一起发送的Transferable对象。
假定当前网页弹出一个新窗口。
var popup = window.open(...popup details ...);
然后在当前网页上监听message事件。
window.addEventListener('message', receiveMessage, false); function receiveMessage(e) { if (e.origin != 'http://example.org') { return; } console.log(e.data); }
上面的代码指定message事件的回调函数是receiveMessage,一旦收到其他窗口发来的信息,receiveMessage函数就会被调用。receiveMessage函数接受一个event事件对象作为参数,该参数里的origin属性表示信息的来源网址,如果该网址不符合要求,就立刻返回。event.data属性则包含了实际发送过来的信息。
event对象的属性除了origin和data,还有一个source属性,指向向当前网页发送信息的窗口对象。
接着,在当前网页上使用postMessage方法对新窗口发送信息。
popup.postMessage('hello world!', 'http://example.org');
上面代码的postMessage方法的第一个参数是实际发送的信息,第二个参数是指定发送对象的域名必须是http://example.org。如果对方窗口不是这个域名,信息不会发送出去。
最后,在popup窗口中部署下面的代码。
//popup 窗口function receiveMessage(event) { event.source.postMessage('Nice to see you!', '*'); } window.addEvengtListener('message', receiveMessage, false);
上面代码有几个地方需要注意。首先,receiveMessage函数里面没有过滤信息的来源,任意网址发来的信息都会被处理。其次,postMessage方法中指定的目标窗口的网址是一个星号,表示该信息可以向任意网址发送。通常来说,这两种做法是不推荐的,因为不够安全,可能会被对方过滤掉。
所有浏览器都支持这个方法,但是IE8和IE9只允许postMessage方法与iFrame窗口通信,不能与新窗口通信。IE10允许与新窗口通信,但是只能使用IE特有的MessageChannel对象
以上就是HTML5新特性之跨文档消息传输详解的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的HTML5新特性之跨文档消息传输详解全部内容,希望文章能够帮你解决HTML5新特性之跨文档消息传输详解所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。