不同域iframe主动与父容器通讯的方法

web前端(H5、混合APP)开发中,经常会遇到跨域的坑,而基于iframe的跨域更是坑中巨坑。而且也会常常遇到父容器与iframe页面间进行交互操作的需求,可以称之为通讯。一般跨域有几种情况:

1、主域(domain)相同,子域不同

相对来讲这种跨域是最好处理的,只要设置document.domain = "主域" 即可。

2、两个域之间好不相干

这种详情是最坑爹的,如果iframe嵌入的是别的站点,且该站点不能配合我们进行通讯处理,那么,我下面所讲的方法基本没戏。

那么,iframe页面怎么主动与父容器进行通讯呢?

方法如下:

1)在主页面main.html,添加一个H5的消息监听事件:

window.addListenerEvent(‘message‘, function(e){

  //处理消息

}, fasle);

2)在iframe页面iframe.html,添加一个发送消息的函数

<script>

  function postParentMessage(data){

    top.postMessage(data, ‘*‘);

  }

</script>

3)在iframe页面需要发送消息给父容器的地方调用postParentMessage函数

<script>

  function pay(orderId){

    postParentMessage(orderId);

  }

</script>

<a href="#" onclick="pay(orderId);">支付</a>

可以尝试一下!

GOOD LUCK!

时间: 2024-10-13 17:38:39

不同域iframe主动与父容器通讯的方法的相关文章

谷歌、火狐浏览器下实现JS跨域iframe高度自适应的完美解决方法,跨域调用JS不再是难题!

谷歌.火狐浏览器下实现JS跨域iframe高度自适应的解决方法 导读:今天开发的时候遇到个iframe自适应高度的问题,相信大家对这个不陌生,但是一般我们都是在同一个项目使用iframe嵌套页面,这个ifame高度自适应网上一搜一大把,今天要讲的如何在不同的网站下进行相互的调用跟在同一个网站下是一个效果:例如我在自己的项目里面Iframe  了第一博客的页面  http://www.diyibk.com/   当第一博客的页面高度变化了怎么通知父页面呢? 这个时候在谷歌下肯定是拿不到 ifram

完美实现跨域Iframe高度自适应【Iframe跨域高度自适应解决方案】

Iframe的强大功能偶就不多说了,它不但被开发人员经常运用,而且黑客们也常常使用它,总之用过的人知道它的强大之处,但是Iframe有个致命的“BUG”就是iframe的高度无法自动适应,这一点让很多人都头疼万分.百度或是谷歌一下,确实很多解决方法,但尝试一下,会发现问题很多:浏览器兼容性差,不能自适应,仅支持同域Iframe等诸多问题,尤其是跨域Iframe高度自适应问题.网上根本找不到一种可行的方案(唯一有一种提到加入代理页面的,经过测试发现无用).难道真的没有一种可行的解决方案了吗? No

同域iframe的高度自适应

引子 父页面里控制子页面 子页面里控制父页面 一.引子 我们先看一个示例,有两个页面,1.html通过iframe嵌入2.html,两个页面都是同域的 1.html <!DOCTYPE html> <html> <head> <meta charset='utf-8' /> <title>1.html</title> </head> <body> <iframe id="ifr" sr

实现跨域iframe接口方法调用 简单介绍

实现跨域iframe接口方法调用 简单介绍: 页面a.html域名为www.a.com,嵌入页面http://www.b.com/b.html. b.html要调用a.html中的js函数,由于两个页面不在一个域中,会提示没权限. 下面就介绍一下如何如何解决此问题,需要的朋友可以做一下参考. 一.cross.js代码如下: (function(global){ global.Cross = { signalHandler: {}, on: function(signal, func){ this

跨域iframe的高度自适应

原文:跨域iframe的高度自适应 跨子域的iframe高度自适应 完全跨域的iframe高度自适应 同域的我们可以轻松的做到 1. 父页面通过iframe的contentDocument或document属性访问到文档对象,进而可以取得页面的高度,通过此高度值赋值给iframe tag. 2. 子页面可以通过parent访问到父页面里引入的iframe tag,进而设置其高度. 但跨域的情况则不允许对子页面或父页面的文档进行访问(返回undefined),所以我们要做的就是打通或间接打通这个壁

Ajax跨域、Json跨域、Socket跨域和Canvas跨域等同源策略限制的解决方法

同源是指同样的协议.域名.port,三者都同样才属于同域.不符合上述定义的请求,则称为跨域. 相信每一个开发者都曾遇到过跨域请求的情况,尽管情况不一样,但问题的本质都能够归为浏览器出于安全考虑下的同源策略的限制. 跨域的情形有非常多,最常见的有Ajax跨域.Socket跨域和Canvas跨域.以下列举一些我们常见的跨域情形下.某些浏览器控制台给出的错误提示: FireFox下的提示: 已阻止交叉源请求:同源策略不同意读取***上的远程资源.能够将资源移动到同样的域名上或者启用 CORS 来解决问

Jquery取得iframe中元素的几种方法Javascript Jquery获取Iframe的元素、内容或者ID

query取得iframe中元素的几种方法 在iframe子页面获取父页面元素代码如下: $('#objId', parent.document);// 搞定... 在父页面 获取iframe子页面的元素代码如下: $("#objid",document.frames('iframename').document) 显示iframe中body元素的内容. $(document.getElementById('iframeId').contentWindow.document.body)

DotNetBar.Bar作为容器使用的方法及Text更新原理

DotNetBar.Bar作为容器使用的方法及Text更新原理 ???????????????????????? 老帅 ?? 一.容器用法?? 控件DevComponents.DotNetBar.Bar是能够有多种用途的,当中一种是用作容器,例如以下图的SQLServer管理器.就是一个容器.容器里面存在两个页面"对象资源管理器具体信息"和"对象资源管理器".这两个页面上又分别容纳了多种控件. ?? 想让DevComponents.DotNetBar.Bar作为容器

iframe中的各种跳转方法

iframe中的各种跳转方法(转) 一.背景A,B,C,D都是jsp,D是C的iframe,C是B的iframe,B是A的iframe,在D中跳转页面的写法区别如下. 二.JS跳转window.location.href.location.href 本页面跳转,D页面跳转parent.location.href 上一层页面跳转,C页面跳转top.location.href 最外层页面跳转,A页面跳转 三.链接或者formD页面中有form < form>: form提交后D页面跳转<fo