基本介绍
HTML5提供了在网页文档之间互相接收与发送信息的功能。使用这个功能,只要获取到网页所在窗口对象的实例,不仅同源(域+端口号)的Web网页之间可以互相通信,甚至可以实现跨域通信。
要想授受从其他窗口发送来的信息,必须对窗口对象的message事件进行监听,代码如下:
window.addEventListener("message", function(event) { // 处理程序代码 }, false);
使用window对象的postMessage()方法向其他窗口发送消息,该方法的定义如下:
otherwindow.postMessage(message, targetOrigin);
该方法使用两个参数:第一个参数为所发送的消息文本,但也可以是任何JavaScript对象(通过JSON转换对象为文本);第二个参数为接收消息的对象窗口的URL地址,可以在URL地址字符串中使用通配符“*”指定全部地址,不过建议使用准确的URL地址。otherwindow为要发送窗口对象的引用,可以通过window.open()方法返回该对象,或通过对window.frames数组指定序号(index)或名字的方式来返回单个frame所属性的窗口对象。
跨域示例
主页面向iframe子页面发送消息,iframe子页面显示接收到的消息,然后向主页面返回消息,最后主页面接收消息并使用提示框显示该消息。
主页面代码如下:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"/> <title>跨文档消息传输示例主文档</title> <script type="text/javascript" src="http://code.jquery.com/jquery-1.6.4.min.js"></script> <script type="text/javascript"> $(function() { // 监听message事件。 window.addEventListener("message", function(event) { // 忽略指定URL之外的页面发送的消息。 if(event.origin != "http://www.blue-butterfly.net") return; alert(event.data); // 显示消息。 }, false); $("#iframeContent").load(function(event) { // 向子页面发送消息 this[0].postMessage("Hello", "http://www.blue-butterfly.net/test/"); }); }); </script> </head> <body> <header> <h1>跨域通信示例</h1> </header> <iframe id="iframeContent" width="400" src="http://www.blue-butterfly.net/test/"></iframe> </body> </html>
子页面中的代码如下:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"/> <script type="text/javascript" src="http://code.jquery.com/jquery-1.6.4.min.js"></script> <script type="text/javascript"> $(function() { window.addEventListener("message", function(event) { if(event.origin != "http://Lulingniu") return; $("#console").append(event.origin).append("传来的消息:").append(event.data); // 向主页面发送消息。 event.source.postMessage("Hello, there is :" + this.location, event.origin); }, false); }); </script> </head> <body> <p>这是iframe中的内容。</p> <div id="console"></div> </body> </html>
- 通过对window对象的message事件进行监听,可以接收消息。
- 通过访问message事件的origin属性,可以获取消息的发送源(本例中主页面的发送源为“http://Lulingniu”,子页面的发送源为“http://www.blue-butterfly.net”)。注意:发送源与网站的URL地址不是一个概念,发送源只包括域名与端口号,为了不接收其他源恶意发送过来的消息,最好对发送源做检查。
- 通过访问message事件的data属性,可以取得消息内容(可以是任何JavaScript对象,使用JSON)。
- 使用postMessage()方法发送消息。
- 通过访问message事件的source属性,可以获取消息发送源的窗口的代理对象。
发表评论
-
使用选择器在页面中插入内容
2011-11-08 10:09 0使用选择器来插入文字 使用选择器来插入内容 在CSS2中, ... -
HTML5 绘制图形【4】
2011-11-08 08:39 1673绘制变形图形 坐标变换 绘制图形的时候,我们可能会想要旋转 ... -
CSS3 选择器【2】
2011-11-07 14:30 1051UI元素状态伪类选择器 UI元素状态伪类选择器的共同特征是: ... -
HTML5 绘制图形【3】
2011-11-05 19:28 1286绘制渐变图形 渐变是指在填充时从一种颜色慢慢过渡到另外一种颜 ... -
CSS3 选择器【1】
2011-11-06 12:19 1672选择器概述 选择器是CS ... -
HTML5 绘制图形【2】
2011-11-04 11:42 1379使用路径 绘制圆形 要 ... -
HTML5 绘制图形【1】
2011-11-03 12:48 1457canvas元素基础 canvas元素是HTML5中新增的一 ... -
CSS3 模块化结构
2011-11-03 19:12 1462CSS3中的模块 模块名称 功能描述 Basi ... -
HTML5 获取地理位置信息
2011-11-01 18:12 5406Geolocation API的基本知识 在HTML5中,为 ... -
HTML5 使用Web Worker处理线程
2011-11-01 09:16 4607基础知识 Web Worker是在HTML5中新增的,用来在 ... -
HTML5 Web Sockets通信
2011-10-29 20:15 4053基础介绍 Web Sockets是HTML5提供的在Web应 ... -
HTML5 离线应用程序【2】
2011-10-27 20:48 1817applicationCache对象 application ... -
HTML5 离线应用程序【1】
2011-10-27 14:02 1517离线Web应用程序介绍 在HTML5中新增了一个API,为离 ... -
HTML5 本地数据库
2011-10-24 21:03 2553本地数据库的基本概念 ... -
HTML5 Web Storage
2011-10-24 15:51 1563Web Storage简单使用 在HTML5中重新提供了一种 ... -
HTML5 多媒体播放【3】
2011-10-23 10:45 1213video元素和audio元素的方法 play()方法:使 ... -
HTML5 多媒体播放【2】
2011-10-22 21:14 1717音频和视频元素的属性 这两种元素所具有的属性大致相同,介绍如 ... -
HTML5 多媒体播放【1】
2011-10-21 18:58 896video与audio元素基础 在HTML5中,video元 ... -
HTML5 拖放API
2011-10-17 19:43 4932在HTML5中,已经支持在浏览器与其他应用程序之间的数据互相拖 ... -
HTML5 文件API
2011-10-16 18:49 4967在HTML5中,提供了一个关于文件操作的文件API,通过使用这 ...
相关推荐
想实现跨文档消息传输首先要对窗口对象的message事件进行监听,然后使用window对象的postMessage()方法向其他窗口发送消息,接下来为大家详细介绍下,感兴趣的朋友可以参考下哈
第7章用单点登录和获取批量数据这2个案例讲解了html 5中的跨文档的消息传输技术;第8章用2个案例讲解了如何利用web workers实现多线程处理;第9章用1个案例讲解了如何利用geolocation api来获取地理位置信息;第10~...
HTML5新增通信相关两个API,跨文档消息传输与WEB Sockets API, 跨文档消息传输功能,可以在不同网页文档,不同端口(跨域情况下)进行消息传递。 使用web sockets api 可以让客户端与服务器端通过socket端口传递...
6.1.2 跨文档消息通信的浏览器支持情况 122 6.1.3 使用postMessage API 123 6.1.4 使用postMessage API创建应用 124 6.2 XMLHttpRequest Level 2 128 6.2.1 跨源XMLHttpRequest 129 6.2.2 进度事件 130 6.2.3...
第7章用单点登录和获取批量数据这2个案例讲解了html 5中的跨文档的消息传输技术;第8章用2个案例讲解了如何利用web workers实现多线程处理;第9章用1个案例讲解了如何利用geolocation api来获取地理位置信息;第10~...
本文档是 Java 2 Platform Standard Edition 6.0 的 API 规范。 请参见: 描述 Java 2 Platform 软件包 java.applet 提供创建 applet 所必需的类和 applet 用来与其 applet 上下文通信的类。 java.awt 包含...
1.3 HTML的基本结构 5 1.3.1 HTML文件的编写方法 5 1.3.2 文件开始标签<html> 7 1.3.3 文件头部标签<head> 7 1.3.4 文件标题标签<title> 7 1.3.5 文件主体标签<body> 7 1.3.6...
针对这些令人头疼的跨域问题,html5特地推出新功能–postMessage(跨文档消息传输)。postMessage在使用时,需要传入2个参数,data和originUrl。data是指需要传递的内容,但是部分浏览器只能处理字符串参数,所以我们...
java.awt.dnd Drag 和 Drop 是一种直接操作动作,在许多图形用户界面系统中都会遇到它,它提供了一种机制,能够在两个与 GUI 中显示元素逻辑相关的实体之间传输信息。 java.awt.event 提供处理由 AWT 组件所激发的...
(4)针对系统的功能实现问题,通过结合利用原生态框架与HTML5的跨平台性,实现了“认我测”在线认证检测系统。 综上所述,“认我测”在线认证检测系统,率先填补了认证检测领域移动端的空缺,提供了Web浏览器+...
XML案例解析教程 eXtensible Markup Language 可扩展标记语言 ...它是Internet环境中跨平台的、依赖于内容的技术,是这个时代中处理分布式结构信息的选择工具,用它来简化通过Internet的文档信息传输。
java.awt.dnd Drag 和 Drop 是一种直接操作动作,在许多图形用户界面系统中都会遇到它,它提供了一种机制,能够在两个与 GUI 中显示元素逻辑相关的实体之间传输信息。 java.awt.event 提供处理由 AWT 组件所激发的...
5、采用了Com组件和JavaBean组件技术,很好的实现了跨平台系统,便于开发。 运行环境 =============================================================================== 硬件平台: 台式机 CPU ...
HTML5 1、WEB基础知识(了解) 1、Internet - 网 由若干台电脑、手机、平板 通过 网线(WIFI) 连接起来的结构 2、基于Internet上的程序 1、C / S 结构 Client / Server 特点:必须通过指定的客户端软件才能访问...
5、采用了Com组件和JavaBean组件技术,很好的实现了跨平台系统,便于开发。 运行环境 =============================================================================== 硬件平台: 台式机 CPU ...