亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

IE8中動態創建script標簽onload無效的解決方法

2019-11-20 13:38:46
字體:
來源:轉載
供稿:網友

本文實例講述了IE8中動態創建script標簽onload無效的解決方法。分享給大家供大家參考。具體分析如下:

今天做項目,發現一個奇怪的問題,動態創建的script標簽在IE8下無法觸發onload事件。

代碼如下:

復制代碼 代碼如下:
var loadJs = function(src, fun){
    var script = null;
    script = document.createElement("script");
    script.type = "text/javascript";
    script.src = src;
    if(typeof fun === "function"){
        script.onload = fun;
    }
 
    document.getElementsByTagName("head")[0].appendChild(script);
};
 
loadJs("js/jquery-1.11.0.min.js", function(){
    console.log("From jQuery");         
});
 
loadJs("test.js", function(){
    console.log("From test.js");         
});
test.js:
console.log(typeof jQuery);

運行結果:
復制代碼 代碼如下:
undefined  // test.js運行時,jQuery還未加載
>> typeof jQuery  // 從控制臺上運行,卻找到了jQuery對象,證明加載順序問題
"function"

并且以上代碼中script.onload并沒有執行,明明代碼已經加載進來了,為什么還是onload不執行呢?到網上一查發現眾多前端開發人員都遇到這個棘手的問題,于是找到了一些替補方案,如下:
復制代碼 代碼如下:
var loadJs = function(src, fun){
    var script = null;
    script = document.createElement("script");
    script.type = "text/javascript";
    script.src = src;
    if(typeof fun === "function"){
        script.onreadystatechange = function() {
            var r = script.readyState;
            console.log(src + ": " + r);
            if (r === 'loaded' || r === 'complete') {
                script.onreadystatechange = null;
                fun();
            }
        };
    }
 
    document.getElementsByTagName("head")[0].appendChild(script);
};

執行結果:
復制代碼 代碼如下:
undefined 
js/jquery-1.11.0.min.js: loading 
test.js: complete 
From test.js 
js/jquery-1.11.0.min.js: loaded 
From jQuery

執行步驟為,這下類似于onload的功能算然算是找到了,但卻有一個問題,它不是按順序加載的,當jQuery文件loading的時候,test.js已經complete了,并且第一行就先執行了test.js的內容。因為test.js先于jQuery執行,所以才打出undefined。于是我們可以改寫成這樣,讓它線性加載:
復制代碼 代碼如下:
loadJs("js/jquery-1.11.0.min.js", function(){
 
    console.log("From jQuery"); 
 
    loadJs("test.js", function(){
        console.log("From test.js");         
    });       
});

執行結果:
復制代碼 代碼如下:
js/jquery-1.11.0.min.js: loading 
js/jquery-1.11.0.min.js: loaded 
From jQuery 
function
test.js: complete 
From test.js

這次,執行的順序完全是按照我們預訂的順序來了,但以上代碼看著很別扭,需要層層嵌套,于是又發現了這種寫法:
復制代碼 代碼如下:
var loadJs = function(src, fun){
    var script = null;
    script = document.createElement("script");
    script.type = "text/javascript";
    script.src = src;
    if(typeof fun === "function"){
        script.onreadystatechange = function() {
            var r = script.readyState;
            console.log(src + ": " + r);
            if (r === 'loaded' || r === 'complete') {
                script.onreadystatechange = null;
                fun();
            }
        };
    }
 
    document.write(script.outerHTML);
    //document.getElementsByTagName("head")[0].appendChild(script);
 
};
 
loadJs("js/jquery-1.11.0.min.js", function(){
    console.log("From jQuery"); 
});
 
loadJs("test.js", function(){
    console.log("From test.js");         
});

執行結果的順序,也不相同:
復制代碼 代碼如下:
function
js/jquery-1.11.0.min.js: loaded 
From jQuery 
test.js: loaded 
From test.js

如果你改變一下加載順序
復制代碼 代碼如下:
loadJs("test.js", function(){
    console.log("From test.js");         
});
 
loadJs("js/jquery-1.11.0.min.js", function(){
    console.log("From jQuery"); 
});

執行結果也就不一樣,類似順序加載:
復制代碼 代碼如下:
undefined 
test.js: loaded 
From test.js 
js/jquery-1.11.0.min.js: loaded 
From jQuery

希望本文所述對大家的javascript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品国产综合久久香蕉最新版| 久久福利视频导航| 国产成人综合av| 亚洲精品中文字幕有码专区| 57pao国产精品一区| 国产情人节一区| 欧美性做爰毛片| 另类视频在线观看| 欧美伦理91i| 日韩最新中文字幕电影免费看| 成人免费网站在线观看| 日本一区二区三区在线播放| 国产精品美乳在线观看| 精品视频在线播放免| 91精品国产综合久久香蕉的用户体验| 日韩中文字幕在线精品| 欧美大片va欧美在线播放| 久久激情五月丁香伊人| 午夜精品久久久久久久99黑人| 国产精品久久二区| 国产激情999| 国产福利视频一区二区| 亚洲欧美一区二区三区情侣bbw| 国外成人免费在线播放| 狠狠色噜噜狠狠狠狠97| 日韩美女视频免费在线观看| 亚洲人精选亚洲人成在线| 日韩免费av片在线观看| 一道本无吗dⅴd在线播放一区| 亚洲美女精品久久| 久久久影视精品| 亚洲最大成人网色| 国产色婷婷国产综合在线理论片a| 欧美电影电视剧在线观看| 欧美电影在线观看高清| 欧美性jizz18性欧美| 91精品视频观看| 国产精品久久久亚洲| 日韩欧美中文在线| 日韩视频在线免费观看| 精品国偷自产在线| 国产久一一精品| 国产精品99久久久久久www| 亚洲人成网在线播放| 色综合久久88色综合天天看泰| 亚洲欧洲午夜一线一品| 日本一区二区三区四区视频| 高清视频欧美一级| 亚洲国产成人精品久久久国产成人一区| 国产精品久久久久国产a级| 91香蕉嫩草神马影院在线观看| 久久久久久69| 国产精品69久久| 97在线免费观看视频| 欧洲永久精品大片ww免费漫画| 久久久久久久久久久久久久久久久久av| 日韩有码在线视频| 国产精品jvid在线观看蜜臀| 国产91露脸中文字幕在线| 国产激情视频一区| 亚洲欧美国产另类| 国产亚洲aⅴaaaaaa毛片| 欧美激情国产日韩精品一区18| 成人免费观看49www在线观看| 欧美性猛交xxxx免费看| 色综合天天综合网国产成人网| 日韩精品在线观看一区| 久久久免费观看视频| 午夜精品福利视频| 国产精品人成电影| 亚洲午夜av电影| 久久99国产精品久久久久久久久| 欧美日韩国产成人在线观看| 国产精品小说在线| 国产精品 欧美在线| 欧美黑人视频一区| 欧美精品成人91久久久久久久| 亚洲乱码国产乱码精品精天堂| 国产亚洲成精品久久| 久久av在线播放| 欧美电影免费观看电视剧大全| 91在线视频成人| 国产这里只有精品| 一本色道久久88综合亚洲精品ⅰ| 久久久久国产精品www| 久久久久久久久国产| 日韩极品精品视频免费观看| 亚洲成年网站在线观看| 91在线视频导航| 色哟哟亚洲精品一区二区| 97久久精品人人澡人人爽缅北| 色婷婷综合久久久久中文字幕1| 北条麻妃久久精品| 久久大大胆人体| 欧美日韩aaaa| 国产亚洲欧美aaaa| 国产精品扒开腿爽爽爽视频| 国产精品偷伦视频免费观看国产| 国产精品久久久久高潮| 欧美影院久久久| 国产视频精品久久久| 在线播放国产一区中文字幕剧情欧美| 国产免费观看久久黄| 欧美综合一区第一页| 最近中文字幕2019免费| 欧美日韩裸体免费视频| 欧美精品电影在线| 欧美日韩中文在线| 亚洲欧美一区二区三区久久| 亚洲一区二区三区xxx视频| 亚洲精品永久免费| 亚洲护士老师的毛茸茸最新章节| 亚洲精品一区av在线播放| 欧美多人爱爱视频网站| 91伊人影院在线播放| 成人字幕网zmw| 亚洲一区二区三区久久| 一本色道久久88综合日韩精品| 成人天堂噜噜噜| 日本中文字幕成人| 亚洲自拍欧美色图| 日本欧美中文字幕| 亚洲国产日韩一区| 日韩中文字幕网| 久久久免费精品视频| 欧美激情综合色综合啪啪五月| 亚洲另类欧美自拍| 日韩亚洲成人av在线| 中文字幕免费精品一区| 狠狠躁18三区二区一区| 精品人伦一区二区三区蜜桃网站| 国产亚洲视频在线观看| 国产视频亚洲视频| 亚洲男人天堂久| 亚洲一区二区久久久久久久| 欧美午夜视频在线观看| 91国产精品视频在线| 国产免费一区视频观看免费| 91精品啪aⅴ在线观看国产| 久久久精品美女| 亚洲人成网站777色婷婷| 欧美日韩一区二区免费视频| 91成人国产在线观看| 中文字幕亚洲第一| 日韩理论片久久| 久久青草福利网站| 亚洲成人av片在线观看| 国产精品久久久久久久久久三级| 久久综合国产精品台湾中文娱乐网| 色中色综合影院手机版在线观看| 亚洲一品av免费观看| 日韩不卡在线观看| 亚洲欧美日韩精品久久奇米色影视| 理论片在线不卡免费观看| 亚洲国产精品va在线看黑人| 777777777亚洲妇女| 国产欧美日韩高清| 91精品国产自产在线观看永久| 欧美视频专区一二在线观看| 国产精品久久久精品| 国模精品视频一区二区三区| 国产精品com| 国产视频精品xxxx| 96pao国产成视频永久免费|