摘要:简介一个利用的跨域解决一个系统中,多个跨域通信交互的库。然而各系统采用了不同的域名,与主框架系统和其它业务系统有跨域问题若将所有域名改为同一域名下可能会产生一些系统间页面元素和样式的冲突故采用了标准下的来解决该问题。
简介
一个利用html5的跨域api postMessage解决一个系统中,多个iframe跨域通信交互的js库。
github地址 :cross-domain
背景最初公司只有一个系统来做销售,随着公司业务越来越多,搭建很多类似的系统(这些系统本来是没有任何关系的,每个系统目前都非常复杂)。
由于目前公司战略有调整,原来的销售是针对某种产品,现在销售工作要针对客户进行多产品的销售促成,这样一个销售人员就需要打开各种系统进行业务操作,非常不方便,而且销售数据间不能有效传递,所就需要把各个不相关的系统整合在一起,实现跨业务线销售和数据共享。若将这想要将这些复杂系统整合在一起,无论是从人力物力上都是不太可能接受的。
所以选择了使用iframe将各系统嵌入一个框架系统,各系统从物理上还是分开不变,而从逻辑上(从用户角度看就是一个系统)看起来是一个系统。
然而各系统采用了不同的域名,与主框架系统和其它业务系统有跨域问题(若将所有域名改为同一域名下可能会产生一些系统间页面元素和样式的冲突)
故采用了HTML5标准下的postMessage来解决该问题。
介绍示意图
http://a.com 是最外层主系统的页面,为master
http://b.com 和 http://c.com 为被嵌入的子系统slave,当然也可以嵌入N个子系统
master和slave都是有各自的域名,由于浏览器的安全限定,两个iframe正常是不能进行数据交换和api调用的。当然有一些特殊方法如jsonp,iframe name等。如果想了解,可以看看我的另一篇文章jsonp实现原理 。
在HTML5中新增了postMessage方法,postMessage可以实现跨文档消息传输(Cross Document Messaging),Internet Explorer 8, Firefox 3, Opera 9, Chrome 3和 Safari 4都支持postMessage。postMessage api详细介绍,请查看 postMessage
示意图如下:
https://raw.githubusercontent...
js库提供了简洁的调用和提供接口的方法,介绍如下
接口调用(向其它iframe发送数据)
/** * 发送消息方法 * @param {String} componentName组件名称 * @param {String} method接口名称(对方通过API extends提供的接口名) * @param {Object} data数据 * @param {Function} callback回调 */ send : function(componentName,method,data,callback,type);
提供接口(提供前端接口,可供其它iframe调用)
/** * 扩展接口方法,供调用方send方法调用 * @param {String} name接口名称 * @param {Function} fun 接口方法 */ extends : function(name,fun);例子
Master代码如下
启动http服务,http://localhost/cross-domain...
Test Page Test Page MASTER
Slave1
启动http服务,http://127.0.0.1/cross-domain...
slave1 I am salve1 frame
Slave2
启动http服务,http://127.0.0.1/cross-domain...
slave2 I am slave2 frame
交互效果
应用案例某企业作业系统
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/95831.html
摘要:四传递信息给父页面参考跨域子页面传给父页面父页面代码崔涣测试父页面参数中有属性,就是父窗口发送过来的数据把父窗口发送过来的数据显示在子窗口中。五简单分析和安全问题传送过来的信息如下图,几乎包含了所有应该有的信息。 背景:由于同源策略存在,javascript的跨域一直都是一个棘手的问题。父页面无法直接获取iframe内部的跨域资源;同时,iframe内部的跨域资源也无法将信息直接传递给...
阅读 3606·2021-11-15 11:38
阅读 2801·2021-11-11 16:55
阅读 2550·2021-11-08 13:22
阅读 2627·2021-11-02 14:45
阅读 1303·2021-09-28 09:35
阅读 2568·2021-09-10 10:50
阅读 463·2019-08-30 15:44
阅读 2775·2019-08-29 17:06