iframe onload事件被block的坑

更新日期: 2019-07-21阅读: 2.6k标签: iframe

写在前面

最近接手了一个古旧的项目,跟客户端、服务器端一起调一个支付相关的app内嵌H5页面,这个页面有两部分组成,主页面A加上一个最终支付页面B,B页面是通过iframe嵌入到A页面中的,A、B两个页面之间的交互采用postMessage+hashChange。
一般除了下载之类的需求,我很少在自己的项目中使用iframe,像这样的两个页面切换的问题,第一反应都是分开写的,不会使用iframe套在一起。
因为项目代码比较老了,我也不太敢动,主要还是在上面修修补补,基本逻辑理通之后,我在自己的安卓测试机上调试了一番,一路通顺,完全没有问题。我把访问链接给到客户端,让他试一下,客户端反映,B页面出不来。
可是在我手机上明明是好的啊,怎么突然显示不出来了呢。


尝试方法

第一反应,有的手机可以,有的手机不行,是不是代码哪里有兼容性问题。
我用有问题的手机打开线上的支付页面,发现没有任何问题,两个支付页面是共用代码的,排除了兼容性问题,一定是在代码上出了错。
然而当时我基本上没在原有的代码上加什么功能性代码,一时也理不出头绪。
在代码里加调试工具,看见有几个js的ajax网络请求一直pending,长时间pending之后就failed了,这个倒是好解决,反正是静态资源,我直接放在页面里面,或者script标签引入就行了,照做之后,之前有问题的js倒是引入进来了,接着又发现iframe的onload也没有执行,可是调试工具上没有报错。
我对iframe是相当抵触的,平时也没有花时间去好好了解一下它,它的onload无法执行,当下我是一点想法都没有的。
于是关键词求助百度,给出的答案要不说是css的问题,要不是说客户端webview的问题,都尝试了一下,发现一点用处都没有。
我把iframe的src换成了http://www.baidu.com,可以加载。
再换回去我们的链接,还是不行,将app杀个进程,再进去访问,突然就可以了,不同安卓版本的手机尝试了一下,也没发现这个现象跟安卓高低版本之间有什么必然的关系,甚至部分手机有时候可以加载,有时候又不可以。
完全无规律。


解决

之前我都是在客户端webview里面加调试工具看的,我突然想起,调试工具提供的信息有限,不如试一下在chrome中访问看一下。
chrome里面依然显示iframe的onload没有执行,但是这时候终于出现了一行报错,显示“Mixed Content……This request has been blocked; the content must be served over HTTPS”。
原来https和http混用,http请求会被block掉,我回头看了一下,我访问A页面的时候是使用的https协议,但是B页面的iframe使用的是http协议,所以被浏览器直接block掉了,导致onload无法执行。
我再将线上那个可以运行的支付页面的链接拿来一看,人家使用的是http协议!
我的天爷,坑原来在这里等着我,我万万没想到,一个https竟然引起了这么大的麻烦。不止这个iframe,那几个通过ajax请求的js也是同样的问题,都是因为使用的是http,所以被block掉了。
原因找到,迅速解决,在客户端的手机上终于顺利展示。
但是仍然有点奇怪,http://www.baidu.com也是使用...,后来回忆,在换百度这个链接之前杀了一次进程,应该是这个因素导致的。


总结

1.我之前很喜欢混用https和http,没什么具体的依据,想到https就使用https,想到http就用http(因为我们的资源两种协议都支持),这一不留意就给自己挖了个巨坑。
2.iframe + postMessage很好的解决了两个页面传值的问题,可以不借助后端(这样就少了几个后端接口,且也少了中途被劫持篡改的风险),直接跨域传递,这个特性在本次页面中发挥了很大的作用,非常好用。
3.我以后再也再也不排斥iframe了,它的作用大大的。
4.赞美chrome,报错信息来的太是时候了。

原文:https://segmentfault.com/a/1190000020144165

链接: https://www.fly63.com/article/detial/4840

iframe 透明兼容,设置iframe透明背景的方法

如何兼容支持iframe框架的背景透明。通过使用allowtransparency和background-color来设置iframe框架的透明效果。

IE9/IE10使用隐藏iframe异步上传文件问题

表单提交是同步的,会阻塞页面,可以将表单提交到一个iframe中,父页面就不会阻塞了。需要设置form的target属性等于iframe的name属性。服务器端只是单纯对表单提交的响应,可以返回一段script脚本作为http响应流,执行javascript。

JS操作iframe元素

页面中有个iframe元素,iframe元素的src是iframe1.html,怎么在demo1.html页面中操作iframe1.html页面,js先找到iframe元素(比如命名为:oIframe),那么oIframe.contentWindow就是iframe1.html这个页面的window

iframe标签刷新页面停留在当前页

整体思路:在iframe所在当前页面地址url后拼接 #+targetUrl,iframe标签内a标签跳转,父页面添加如下方法,iframe标签内调用父页面js方法用 window.parent.jsfun() 调用。

iframe的父子页面进行简单的相互传值

当一个页面使用了iframe作为嵌套时,如何想要将父页面的数据传给iframe子页面,那iframe所指向的呢个子页面是怎么获取呢,又或者子页面的数据要给父页面使用,那么父页面又如何获取子页面的数据呢?

如何优雅的使用iframe?

iframe在web应用刀耕火种的开发年代是非常常见的,现在基于Node构建的前端应用嵌入iframe的场景越来越少了,但是在大型的web应用中也会经常遇见利用iframe嵌入多个前端应用于一套前端系统中,方便用户在一个系统中去进行业务操作

iframe在iphone手机上的问题

通过document.addEventListener(\\\"scroll\\\",function(){})对页面滚动监听事件进行监听,但ios下$(document).scrollTop()值始终为0,对页面监听无效。

iframe父子传参通信

在最近的项目里面,用到了不少关于iframe父子传参通信的相关操作,记录一下,虽然很简单,但是确实十分有用的;iframe通信可以分为2种,跨域和非跨域两种.分别说明;

iframe中跨域页面访问parent的方法

在AAA.com域名下的index.htm页面中内嵌了BBB.com域名下的一个页面index.htm,正常情况下iframe内部的index.htm页面是无法访问父页面index.htm中的任何dom对象或者js函数的,因为跨域,但我们经常又需要做一些参数回传的事情怎么办呢?以上的这种实现方式就很好的解决了这个问题

iframe高度自适应

我们知道,iframe最大的问题,就是高度的问题,如果你内容的高度是变化,要么你就给你的容器写个固定的高度,如果内容是未知的,显然这个方法并不能达到我们的想要的效果,要么就是通过js来解决这个问题。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!