Internet Explorer 中“script”标签的“onload”处理程序

IT技术 javascript internet-explorer onload
2021-02-08 19:39:35

我一直在使用此函数将 onload 处理程序附加到脚本标记,这似乎是 Internet 上推荐的方法。
然而,如果页面已经加载(在 ie 8 中测试),它在 Internet Explorer 中不起作用。您可以看到它在普通浏览器中工作(加载脚本时触发警报)。

我错过了什么吗?
谢谢

2个回答

您应该致电jQuery.getScript,这正是您正在寻找的。

编辑:这是来自 jQuery 的相关源代码:

var head = document.getElementsByTagName("head")[0] || document.documentElement;
var script = document.createElement("script");
if ( s.scriptCharset ) {
    script.charset = s.scriptCharset;
}
script.src = s.url;

// Handle Script loading
    var done = false;

// Attach handlers for all browsers
script.onload = script.onreadystatechange = function() {
    if ( !done && (!this.readyState ||
            this.readyState === "loaded" || this.readyState === "complete") ) {
        done = true;
        jQuery.handleSuccess( s, xhr, status, data );
        jQuery.handleComplete( s, xhr, status, data );

        // Handle memory leak in IE
        script.onload = script.onreadystatechange = null;
        if ( head && script.parentNode ) {
            head.removeChild( script );
        }
    }
};

// Use insertBefore instead of appendChild  to circumvent an IE6 bug.
// This arises when a base node is used (#2709 and #4378).
head.insertBefore( script, head.firstChild );
我认为“jQuery.handleSuccess( s, xhr, status, data ); jQuery.handleComplete( s, xhr, status, data ); ”可能不是必需的,如果逐字使用会导致错误
2021-03-17 19:39:35
您可以在此处 找到可以使用的相同代码(不含 jQuery 部分)
2021-03-17 19:39:35
不会真正起作用,因为 jquery 最初不可用:我必须像这样加载它。但我会检查来源,看看它是否适用于 IE。+1 有趣的参考,谢谢!
2021-03-25 19:39:35
请注意 IE9+ 支持 script.onload 和 script.onreadystatechange ( bit.ly/18gsqtw ),因此这两个事件都将被触发(即 2 次调用),这就是需要“完成”的原因。如果您需要将其包装在一个module中以帮助多个脚本加载,请记住这一点。
2021-03-26 19:39:35
一个很好的答案,谢谢,您不必使用 jQuery 来学习这种完全有效的方法,然后编写类似的东西。:)
2021-04-10 19:39:35

我也遇到了 script.onload = runFunction; 的问题。在 IE8 中。

我尝试了 jQuery.getScript,它非常适合我的需求。唯一的缺点是在添加脚本之前必须等待 jQuery 加载完毕。

然而,由于我的回调函数非常大量地使用 jQuery,我发现这是一个非常可接受且非常小的缺点,因为它创建了一个非常易于使用的跨浏览器解决方案。

更新:

这是一种不使用 jQuery 的方法:

(修改后的解决方案来自:https : //stackoverflow.com/a/13031185/1339954

var url = 'http://ajax.googleapis.com/ajax/libs/swfobject/2.2/swfobject.js';
var headID = document.getElementsByTagName("head")[0];
var script = document.createElement('script');
script.type='text/javascript';
script.src=url;

//for nonIE browsers
script.onload=function(){
        addVideo();
    }

 //for IE Browsers
 ieLoadBugFix(script, function(){
     addVideo();}
 );

function ieLoadBugFix(scriptElement, callback){
        if (scriptElement.readyState=='loaded' || scriptElement.readyState=='completed') {
             callback();
         }else {
             setTimeout(function() {ieLoadBugFix(scriptElement, callback); }, 100);
         }


 }

headID.appendChild(script);
看起来 jQuery 设法在没有轮询的情况下解决了这个问题。尝试 onreadystatechange 而不是设置超时
2021-03-13 19:39:35
ieLoadBugFix 函数可以很好地完成这项工作。它已经测试过了。我很高兴 stackoverflow 如何帮助提出 8 年前提出的解决方案。太棒了
2021-04-02 19:39:35