IE8为什么不处理iframe onload事件?

时间:2012-10-16 08:31:59

标签: javascript html iframe internet-explorer-8

示例代码:

<!DOCTYPE html>
<html>
<head>
<title></title>
<script>
function on_iframe_load() {
    document.getElementById('iframe_a').onload = function() {
        alert('Thanks for the visit!');
    };
}
</script>
</head>
<body>
<iframe name="iframe_a" id="iframe_a"></iframe>
<a href="http://www.example.com/" target="iframe_a" onclick="on_iframe_load();">Go!</a>
</body>
</html>

它适用于所有主流浏览器,没有问题,但IE8(可能是以前的版本)不理解它。

更新:刚刚提出了一个解决方案,但我不确定它是否正确编码。请查看:

<!DOCTYPE html>
<html>

    <head>
        <title></title>
        <script>
            var clicked = false;

            function activate() {
                clicked = true;
            }

            function pop() {
                if (clicked) {
                    alert('Thanks for the visit!');
                };
            }
        </script>
    </head>

    <body>
        <iframe name="iframe_a" onload="pop();"></iframe>
        <a href="http://www.example.com/" target="iframe_a" onclick="activate();">Go!</a>

    </body>

</html>

4 个答案:

答案 0 :(得分:4)

在iframe上使用内联属性似乎可以解决IE8中的这个问题:

<!DOCTYPE html>
<html>
<head>
<title></title>
<script>
function onIframeLoad(iframe) {
    if(iframe.src) {
        alert('Thanks for the visit!');
    }
}
function onLinkClick(url) {
    document.getElementById('iframe_a').src = url;
}
</script>
</head>
<body>
<iframe id="iframe_a" onload="onIframeLoad(this);"></iframe>
<a href="http://www.example.com/" onclick="onLinkClick(this); return false;">Go!</a>
</body>
</html>

按要求更新:

你应该尝试编写更不引人注目的javascript。以这种方式编写代码可能会阻止您在IE中出现这种奇怪的错误。

<!DOCTYPE html>
<html>
<body>
    <iframe id="display-frame"></iframe>
    <a href="http://www.example.com/">Go!</a>
    <script>
        window.onload = function() {
            var iframe = document.getElementById('display-frame'),
                link = document.getElementsByTagName('a')[0];

            // load handler
            function onIframeLoad() {
                alert('Thanks for the visit!');
            }

            // event handlers
            if(iframe.addEventListener) iframe.addEventListener('load', onIframeLoad, false);
            else if(iframe.attachEvent) iframe.attachEvent('onload', onIframeLoad);

            link.onclick = function() {
                iframe.src = this.href;
                return false;
            }
        };
    </script>
</body>
</html>

答案 1 :(得分:2)

一旦页面加载,似乎无法使用DOM属性向IE中的iFrame添加加载侦听器。

但你可以使用attachEvent,所以:

function on_iframe_load() {
    function foo() {
        alert('Thanks for the visit!');
    };
    var el = document.getElementById('iframe_a');

    if (el.attachEvent) {
      el.attachEvent('onload',foo);
    } else if (el.addEventListener) {
      el.addEventListener('load', 'foo', false);
    }
}

我在IE 6中测试并颠倒了通常的测试顺序,因此attachEvent优先于addEventListener使用addEventListener。您可能希望测试更新版本的IE以查看相反的顺序是否有效,还可以测试其他类似IE的浏览器,例如Opera。

修改

在测试后修改代码(愚蠢的我)以使用function on_iframe_load() { function foo() { alert('Thanks for the visit!'); }; var el = document.getElementById('iframe_a'); if (el.attachEvent) { el.attachEvent('onload',foo); } else { el.onload = foo; } } 。这是适用于IE和其他的东西:

{{1}}

如果在标记中使用onload属性,则无需使用脚本添加侦听器。

答案 2 :(得分:2)

有效:)

在IE8,ff,chrome上测试

var iframe = document.getElementById('iframeid');

    if (iframe .attachEvent) {
      iframe .attachEvent('onload',alert("IE Iframe loaded"));

    } else {
      iframe .onload = alert("Other than IE Iframe loaded");
    }

答案 3 :(得分:2)

只需使用jquery:

$(iframe).bind( 'load', function(){} );