在项目中有应用到不同的子项目,通过不同的二级域名实现相互调用功能。其中一个功能是将播放器作为单独的二级域名的请求接口,其他项目必须根据该二级域名调用播放器。最近需要实现视频播放完毕后的事件触发,调用父窗口中的回调方法。普通的javascript很难实现跨域请求和调用的操作。通过jsonp方式实现起来复杂。不过通过Html的postMessage和onMessage可以轻松实现以上功能。

  • postmessage方法

postMessage()方法允许来自不同源的脚本采用异步方式进行有限的通信,可以实现跨文本档、多窗口、跨域消息传递。postmessage(data,origin)方法含有两个参数

1、data:要发送的数据

支持字符串,数组等基本类型数据,对于对象类型,目前不是所有的浏览器都支持。只有基本类型的对象可以通过JSON.stringfy()方法转换成字符串,再进行传递。如果对象属性中含有方法,则JSON.stringfy()方法会直接跳过该属性,不会生成该属性的字符串。

       2、origin :要发送的完整主机请求地址。

          origin  = 协议 + 主机名 + 端口号。

          如果origin设置为 *表示任何窗口都可以接收数据。

          如果origin设置为/表示只能同源窗口才能接收数据

  • onMessage

onMessage(data, source, origin) 方法监听并接收来自postMessage传递的数据。

1、data:要接收的数据

2、source:发送消息的窗口对象

3、origin 域请求地址,组成跟postMessage中一致。

  • 父窗口给子窗口传递数据
/*-------------------------------------------------------------------------------------------
函数名称:callVideoPlayComplete()
函数功能:通过Html5的postMessage方法实现跨域文档通讯访问
函数参数:
url 通讯地址
data 传输数据,只能是数组、字符串等基本类型,对象类型目前不是所有的浏览器都支持
callFnBack 回调方法
函数说明:
-------------------------------------------------------------------------------------------*/
function callVideoPlayComplete(ifmId, url, data, callFnBack){
var objIfm = document.getElementById(ifmId); if(objIfm){
if(document.getElementById(ifmId).contentWindow){
if(document.getElementById(ifmId).contentWindow.postMessage){
document.getElementById(ifmId).contentWindow.postMessage(JSON.stringify(data), url); /*监听返回结果*/
window.addEventListener("message", function(event){
/*调用回调函数*/
callFnBack.call(null,null);
}, false );
}else{
alert("您的浏览器版本太低,不支持html5,请升级浏览器到最新版本");
}
}else{
alert("对象不是一个iframe对象");
}
}else{
alert("iframe对象不存在");
}
}
  • 子窗口给父窗口传递数据
/*-------------------------------------------------------------------------------------------
函数名称:callVideoPlayComplete()
函数功能:监听视频播放触发事件跨域跨文档事件完成触发调用回调方法
函数参数:
callFnBack 回调方法
函数说明:
-------------------------------------------------------------------------------------------*/
function callVideoPlayComplete(callFnBack){
/*监听返回结果*/
window.addEventListener("message", function(event){
var origin = event.origin;
var data = event.data; /*调用回调函数*/
callFnBack.call(null,data, origin);
}, false );
}
  • 参考资料

http://www.cnblogs.com/dolphinX/p/3464056.html

http://caniuse.com/#tables

http://www.ibm.com/developerworks/cn/web/1301_jiangjj_html5message/

https://developer.mozilla.org/en-US/docs/Web/API

通过Html5的postMessage和onMessage方法实现跨域跨文档请求访问的更多相关文章

  1. Learning to rank的讲解,单文档方法(Pointwise),文档对方法(Pairwise),文档列表方法(Listwise)

    学习排序(Learning to Rank) LTR(Learning torank)学习排序是一种监督学习(SupervisedLearning)的排序方法.LTR已经被广泛应用到文本挖掘的很多领域 ...

  2. 四种方法 恢复损坏的Excel文档

    四种方法 恢复损坏的Excel文档 打开一个以前编辑好的Excel工作簿,却发现内容混乱,无法继续进行编辑,而且还不能够进行打印.这是很多朋友在处理Excel文件时都可能会遇到的一个问题,面对这种情况 ...

  3. 前后端分离开发,跨域时jsessionid每次请求都变化的问题解决方法

    本解决方法的使用前提是,前端开发使用的是vue,后端使用java(SpringMVC) 在前后端分离开发过程中,可能会出现因跨域而导致每次请求的jsessionid不一致的情况 解决方法: 前端:要在 ...

  4. (二)文档请求不同源之window.postMessage跨域

    一.基本原理 HTML5为了解决跨域,引入了跨文档通信API(Cross-document messaging).这个API为window对象新增了一个window.postMessage方法,允许跨 ...

  5. postMessage解决跨域跨窗口消息传递

    平时做web开发的时候关于消息传递,除了客户端与服务器传值还有几个经常会遇到的问题 页面和其打开的新窗口的数据传递 页面与嵌套的iframe消息传递 这些问题都有一些解决办法,但html5引入的mes ...

  6. html5权威指南:标记文字、组织内容、文档分节

    HTML5新增及删除标签:http://www.cnblogs.com/starof/archive/2015/06/23/4581850.html 第八章:标记文字                 ...

  7. [跨域]跨域解决方法之Ngnix反向代理

    跨域原理:http://www.cnblogs.com/Alear/p/8758331.html 介绍Ngnix之前,我么先来介绍下代理是什么~ 代理相当于中间人,中介的概念 代理分为正向代理和反向代 ...

  8. jQuery的$.getScript方法去加载javaScript文档解析

    1.两个文件的代码如下: <script> function Ajax(){ //将9-4.html中的Ajax()函数进行修改 $.getScript('9-8.js',function ...

  9. 您只能在 HTML 输出中使用 document.write。如果您在文档加载后使用该方法,会覆盖整个文档

    https://blog.csdn.net/qq_37425546/article/details/54868908

随机推荐

  1. eclipse 批量 查询 替换

    对于 要对多个jsp 或 java文件中的 某个字符串 方法 参数 之类的进行统一更改,一直很头疼,直到昨天用了 urlrewriter 的 xml 配置文件 才恍然大悟,可以用 regular ex ...

  2. bzoj3878

    当初只会暴力,现在差不多觉得水了显然离线处理,对输入的数排序然后会发现不管怎么修改都是结果总是单调不降的对于每次处理,我们只要找到那段越界的即可显然上线段树,话说jsoi这么喜欢线段树?下面在bzoj ...

  3. 【转】VS2010/MFC编程入门之八(对话框:创建对话框类和添加控件变量)

    原文网址:http://www.jizhuomi.com/software/153.html 前两讲中鸡啄米为大家讲解了如何创建对话框资源.创建好对话框资源后要做的就是生成对话框类了.鸡啄米再声明下, ...

  4. XML常用颜色值

    <?xml version="1.0" encoding="utf-8" ?> <resources> <color name=& ...

  5. FZU 2092 收集水晶 dp+bfs

    定义dp[t][x1][y1][x2][y2]为在t时刻,人走到x1,y1,影子走到x2,y2所获得最大价值 最终就是所有的dp[max][..][..][..][..]的最大值 然后递推也很自然,枚 ...

  6. POJ 1511 Invitation Cards dij

    分析:正向加边,反向加边,然后两遍dij #include<cstdio> #include<cstring> #include<queue> #include&l ...

  7. 四元数(Quaternion)详细讲解以及在图形图像编程中的使用

    关于四元数介绍可以直接看wiki,写的很详细了. 四元数的基本运算:http://www.linuxgraphics.cn/opengl/opengl_quaternion.html,代码有些问题. ...

  8. bzoj 1925 [Sdoi2010]地精部落(DP)

    Description 传说很久以前,大地上居住着一种神秘的生物:地精. 地精喜欢住在连绵不绝的山脉中.具体地说,一座长度为 N 的山脉 H可分 为从左到右的 N 段,每段有一个独一无二的高度 Hi, ...

  9. 洛谷P1189 逃跑的拉尔夫(SEARCH)

    洛谷1189 SEARCH 题目描述 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且车上装有用于发射车子移动路线的装置. 那个装置太旧了,以至于只能发射关于那辆车的 ...

  10. Android Studio 导入项目错误

    Gradle DSL method not found: 'Android()' 错误原因: android studio 引进项目时,自动查找本机是否有项目设置的SDK版本,若发现没有,我们会在pr ...