基本介绍
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 1705绘制变形图形 坐标变换 绘制图形的时候,我们可能会想要旋转 ... -
CSS3 选择器【2】
2011-11-07 14:30 1113UI元素状态伪类选择器 UI元素状态伪类选择器的共同特征是: ... -
HTML5 绘制图形【3】
2011-11-05 19:28 1326绘制渐变图形 渐变是指在填充时从一种颜色慢慢过渡到另外一种颜 ... -
CSS3 选择器【1】
2011-11-06 12:19 1720选择器概述 选择器是CS ... -
HTML5 绘制图形【2】
2011-11-04 11:42 1435使用路径 绘制圆形 要 ... -
HTML5 绘制图形【1】
2011-11-03 12:48 1531canvas元素基础 canvas元素是HTML5中新增的一 ... -
CSS3 模块化结构
2011-11-03 19:12 1508CSS3中的模块 模块名称 功能描述 Basi ... -
HTML5 获取地理位置信息
2011-11-01 18:12 5440Geolocation API的基本知识 在HTML5中,为 ... -
HTML5 使用Web Worker处理线程
2011-11-01 09:16 4667基础知识 Web Worker是在HTML5中新增的,用来在 ... -
HTML5 Web Sockets通信
2011-10-29 20:15 4141基础介绍 Web Sockets是HTML5提供的在Web应 ... -
HTML5 离线应用程序【2】
2011-10-27 20:48 1875applicationCache对象 application ... -
HTML5 离线应用程序【1】
2011-10-27 14:02 1566离线Web应用程序介绍 在HTML5中新增了一个API,为离 ... -
HTML5 本地数据库
2011-10-24 21:03 2597本地数据库的基本概念 ... -
HTML5 Web Storage
2011-10-24 15:51 1621Web Storage简单使用 在HTML5中重新提供了一种 ... -
HTML5 多媒体播放【3】
2011-10-23 10:45 1246video元素和audio元素的方法 play()方法:使 ... -
HTML5 多媒体播放【2】
2011-10-22 21:14 1749音频和视频元素的属性 这两种元素所具有的属性大致相同,介绍如 ... -
HTML5 多媒体播放【1】
2011-10-21 18:58 955video与audio元素基础 在HTML5中,video元 ... -
HTML5 拖放API
2011-10-17 19:43 4961在HTML5中,已经支持在浏览器与其他应用程序之间的数据互相拖 ... -
HTML5 文件API
2011-10-16 18:49 5033在HTML5中,提供了一个关于文件操作的文件API,通过使用这 ...
相关推荐
HTML5的跨文档消息传输(Cross-document messaging)是一种在不同源的浏览器窗口之间安全地交换信息的方法。这个功能主要是为了处理跨域通信的问题,因为出于安全考虑,浏览器通常禁止不同源的网页之间直接共享数据...
在现代移动应用开发中,H5(HTML5)技术已经成为不可或缺的一部分,特别是在跨平台和物联网(IoT)领域。"H5 蓝牙模块数据传输demo" 是一个基于Hbuilder开发的示例项目,专注于BLE(低功耗蓝牙)的数据通信功能。BLE是...
在标签“跨平台跨语言API文档编写工具.rar”中,“.rar”是文件的压缩格式,它通常用于将多个文件打包成一个文件以便于存储和传输。在这个上下文中,这个标签可能是在强调这个压缩包包含的工具是跨平台的,并且专门...
在IT领域,HTML页面嵌入Word编辑文档是一种常见的需求,特别是在构建富文本编辑器或在线文档处理系统时。本主题将深入探讨如何实现这一功能,以及相关技术的应用和原理。 HTML(HyperText Markup Language)是网页...
这使得XML成为编写结构化、跨平台的开发文档的理想选择,如软件接口定义、数据交换规范等。 XML SDK(Software Development Kit)可能包含一组工具和库,帮助开发者解析、创建、修改XML文档。这些工具可能包括解析...
首先,跨文档消息传输是HTML5中解决不同源(如不同域名、不同端口)网页间通信问题的关键技术。学生需要理解其基本概念,包括如何实现不同页面、不同端口、不同域之间的消息传递。这通常涉及使用`postMessage`和`...
“communication”可能涵盖HTML5的跨文档消息传递(Cross-document messaging)和WebRTC技术。前者允许不同源的页面之间进行通信,而后者则提供了浏览器之间的实时通信能力,支持音频、视频的传输,无需插件,非常...
为了解决跨域请求的问题,HTML5引入了跨文档消息传输(Cross-Origin Communication)的功能。这一功能允许不同源之间的页面进行通信,主要通过两个方法实现:`postMessage`和`onmessage`事件处理器。 - `post...
第7章用单点登录和获取批量数据这2个案例讲解了html 5中的跨文档的消息传输技术;第8章用2个案例讲解了如何利用web workers实现多线程处理;第9章用1个案例讲解了如何利用geolocation api来获取地理位置信息;第10~...
标签“BlueTo 蓝牙 蓝牙传输源码 H5+Blu”进一步细化了主题,其中“BlueTo”可能是对蓝牙(Bluetooth)的简称,“H5+Blu”表明是HTML5与蓝牙技术的结合,而“蓝牙传输源码”则意味着提供了实现蓝牙通信的具体代码。...
HTML5的核心目标是提升用户体验,简化开发流程,并实现跨平台兼容性。它的新特性包括: 1. **语义化标签**:如, , , , 等,这些标签提供了更强的内容结构,帮助搜索引擎更好地理解和索引网页内容。 2. **离线存储*...
PDF格式因其跨平台兼容性和内容保真性而被广泛使用,但有时我们需要将其转换为更便于编辑的Word文档,或者为了在网络上传输和展示,转换成HTML网页或SWF动画。以下将详细介绍这些转换过程和相关知识点: 1. **PDF转...
总的来说,HTML5 Speedtest是一个体现HTML5强大功能的实例,它展示了如何利用现代Web技术解决传统问题,并提供了一个无插件、跨平台的网络速度测试解决方案。通过深入研究和实践,我们可以进一步提升我们的前端开发...
- Flask-Compress可以自动压缩响应内容,提高传输效率。 5. **命令行接口(CLI)** - Flask提供了`flask`命令行工具,可以用于运行应用、初始化数据库等操作。 6. **测试(Testing)** - Flask自带测试客户端,...
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...
HTML格式的优点是跨平台且易于阅读,同时支持链接跳转,使得在文档中查找相关类和方法变得简单快捷。 在使用Java API文档时,开发者通常会关注以下几个方面: 1. 类(Class):了解类的职责、构造器、属性和方法。...
《Hprose_for_HTML5用户手册》是针对在HTML5环境下使用Hprose这一轻量级、跨语言、跨平台的RPC(Remote Procedure Call)框架的详细指南。Hprose是一个强大的开源远程调用解决方案,它支持多种编程语言,包括...
11. 通信API: HTML5引入了跨文档消息传输(Cross-Origin Resource Sharing, CORS),允许文档在不同源之间进行交互式通信。 12. 兼容性与性能: HTML5在浏览器兼容性上做了一些优化。另外,浏览器性能在HTML5时代也...
HTML文档(.xml)是一种基于XML(Extensible Markup Language)标准的数据格式,它主要用于存储和传输结构化数据。XML的设计宗旨是传输和存储数据,而不是显示数据,这与HTML(HyperText Markup Language)的主要...