`
DBear
  • 浏览: 228603 次
  • 性别: Icon_minigender_2
  • 来自: 上海
社区版块
存档分类

【转】Firefox下iframe的onload事件有可能无法触发 作者:zhanglili

阅读更多

Firefox下,已经load的document,重新open再write一个iframe,则这个iframe的onload不会执行。

重现步骤

  1. 在页面中放置一个iframe,并注册一个onload处理函数。
  2. 在该处理函数中,打开iframe的文档流。
  3. 向文档流使用document.write写入一个iframe,这个iframe包含一个onload属性。
  4. 查看onload的处理函数是否执行。

期望结果

iframe的onload处理函数正确执行。

实际结果

第二层iframe的onload函数没有执行。

影响范围

示例代码

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>我去你喵的</title>
</head>
<body>
    <script>
        var loaded = false;
        function load(iframe) {
            if (!loaded) {
                loaded = true;
                var doc = iframe.contentWindow.document;
                doc.open();
                doc.write('<iframe src="about:blank" onload="alert(\'!!\');"><\/iframe>');
                doc.write('</body>');
                doc.close();
            }
        }
    </script>
    <iframe src="about:blank" onload="load(this);"></iframe>
</body>
</html>

解决方案

需要向iframe的文档流写入数据的情况,通常出现在使用一个src为about:blank的iframe元素占位的情况下,因此外层iframe的onload事件没有太大意义。

可以在iframe元素之后内联一段脚本以达到写入iframe的文档流的目的,通过document.getElementsByTagName('iframe')的最后一个获取该iframe元素。

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>我去你喵的</title>
</head>
<body>
    <iframe src="about:blank"></iframe>
    <!-- 以下代替onload -->
    <script>
        var frames = document.getElementsByTagName('iframe');
        var iframe = frames[frames.length - 1];
        var doc = iframe.contentWindow.document;
        doc.open();
        doc.write('<iframe src="about:blank" onload="alert(\'!!\');"><\/iframe>');
        doc.write('</body>');
        doc.close();
    </script>
</body>
</html>

分享到:
评论

相关推荐

    iframe中onload的bug

    NULL 博文链接:https://snandy.iteye.com/blog/666530

    javaScript的onload事件例子

    javaScript的onload事件的代码,javaScript内嵌在html中。

    脱离document.onload和window.onload的onload事件

    脱离document.onload和window.onload的onload事件,可多次添加加载事件!

    微信小程序onLaunch异步,首页onLoad先执行?

    本来按照事件顺序,小程序初始化时触发App里的onLaunch,后面再执行页面Page里的onLoad,但是在onLaunch里请求获取是否有权限,等待返回值的时候Page里的onLoad事件就已经执行了。   //app.js App({ onLaunch: ...

    JS实现兼容火狐及IE iframe onload属性的遮罩层隐藏及显示效果

    本文实例讲述了JS实现兼容火狐及IE iframe onload属性的遮罩层隐藏及显示效果。分享给大家供大家参考,具体如下: &lt;&#37;@ page language=java import=java.util.* pageEncoding=GB2312%&gt; &lt;&#37; String path...

    图片onload事件触发问题解决方法

    并且随页面大小的不同情况... 解决办法是再onload触发前改变图片src的值,也就是相当于图片开始时有个临时的占位图片,页面载入过程中用js换成实际需要的src,只要每次onload事件触发前src发生变化,则onload表现正常。

    js判断iframe内的网页是否滚动到底部触发事件

    之前有个需求是要判断iframe内的网页是否滚动到底部触发事件, 网上找了许多资料都是说在当前页面下的, 索性就自己研究了一下, 找到了解决方法. clientHeight:这个元素的高度,占用整个空间的高度 offsetHeight:是...

    iframe的onreadystatechange事件在firefox下的使用

    firefox不支持iframe的onreadystatechange事件,这个让我调试一下下午。。。 直接贴代码 我这里想做的效果是先生成一个iframe,当我想里面加载内容的时候触发这个事件, 代码可以很清晰的看到用onload方法来进行替代...

    javascript firefox 自动加载iframe 自动调整高宽示例

    iframe 自动获取onload高宽 代码如下: function AutoResize(iframe) { //firefox if(iframe.contentWindow) { iframe.height = iframe.contentWindow.document.documentElement.scrollHeight; iframe.width = iframe...

    js的image onload事件使用遇到的问题

    主要介绍了js的image onload事件使用遇到的问题,需要的朋友可以参考下

    原生javascript如何实现共享onload事件

    在工作时,我们给一个元素绑定了事件,如果dom还没...有一种办法可以让我们避开这一难题:可以先创建一个匿名函数来容纳这两个函数,然后把那个匿名函数绑定到onload事件上,如下所示: [removed] = function(){ fi

    IE iframe的onload方法分析小结

    判断iframe是否加载完成的完美方法IE 支持 iframe 的 onload 事件,不过是隐形的,需要通过 attachEvent 来注册。 第二种方法比第一种方法更完美(采用readystatechange判断),因为 readystatechange 事件相对于 load...

    js的onload事件及初始化按钮事件示例代码

    onload事件当一个页面或是一张图片加载完成时被触发,在body上不仅可以用onload,而且还支持多个HTML标签.用法如下

    判断iframe里的页面是否加载完成

    代码如下: //判断iframe是否加载完成,RMid为iframe的ID document.getElementById(“RMid”).onload = function () { alert&#40;“加载完成”&#41;; } //在父框架操作iframe页面里的AddReceipt2方法 window.frames...

    vant-ui框架的一个bug(解决切换后onload不触发)

    前几天做的项目里有用到下拉刷新。使用了vant-ui里的 List 列表 瀑布流滚动加载,用于控制长列表的展示 先说使用 1.用npm下载该模块包 npm i vant -S 2.引入组件 官方提供了三种方法。(我使用了第三种,全局引入...

    iframe的onload在Chrome/Opera中执行两次Bug的解决方法

    创建iframe对象,添加load事件, 再将iframe添加到body中。Chrome/Opera中会造成load事件的handler执行两次。

    iframe 异步加载技术及性能分析

    iframe会阻塞主页面的onload事件 主页面和iframe共享同一个连接池 阻塞主页面的onload是这两个问题中最影响性能的方面。一般都是想让onload时间越早触发越好,一方面是用户体验过更重要的是google给网站的加载速度的...

Global site tag (gtag.js) - Google Analytics