IE8中動態(tài)創(chuàng)建script標簽onload無效的解決方法
更新時間:2014年12月22日 09:43:53 投稿:shichen2014
這篇文章主要介紹了IE8中動態(tài)創(chuàng)建script標簽onload無效的解決方法,涉及針對javascript加載順序的調(diào)整,具有一定的參考借鑒價值,需要的朋友可以參考下
本文實例講述了IE8中動態(tài)創(chuàng)建script標簽onload無效的解決方法。分享給大家供大家參考。具體分析如下:
今天做項目,發(fā)現(xiàn)一個奇怪的問題,動態(tài)創(chuàng)建的script標簽在IE8下無法觸發(fā)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);
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);
運行結(jié)果:
復制代碼 代碼如下:
undefined // test.js運行時,jQuery還未加載
>> typeof jQuery // 從控制臺上運行,卻找到了jQuery對象,證明加載順序問題
"function"
>> typeof jQuery // 從控制臺上運行,卻找到了jQuery對象,證明加載順序問題
"function"
并且以上代碼中script.onload并沒有執(zhí)行,明明代碼已經(jīng)加載進來了,為什么還是onload不執(zhí)行呢?到網(wǎng)上一查發(fā)現(xiàn)眾多前端開發(fā)人員都遇到這個棘手的問題,于是找到了一些替補方案,如下:
復制代碼 代碼如下:
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);
};
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);
};
執(zhí)行結(jié)果:
復制代碼 代碼如下:
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
js/jquery-1.11.0.min.js: loading
test.js: complete
From test.js
js/jquery-1.11.0.min.js: loaded
From jQuery
執(zhí)行步驟為,這下類似于onload的功能算然算是找到了,但卻有一個問題,它不是按順序加載的,當jQuery文件loading的時候,test.js已經(jīng)complete了,并且第一行就先執(zhí)行了test.js的內(nèi)容。因為test.js先于jQuery執(zhí)行,所以才打出undefined。于是我們可以改寫成這樣,讓它線性加載:
復制代碼 代碼如下:
loadJs("js/jquery-1.11.0.min.js", function(){
console.log("From jQuery");
loadJs("test.js", function(){
console.log("From test.js");
});
});
console.log("From jQuery");
loadJs("test.js", function(){
console.log("From test.js");
});
});
執(zhí)行結(jié)果:
復制代碼 代碼如下:
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
js/jquery-1.11.0.min.js: loaded
From jQuery
function
test.js: complete
From test.js
這次,執(zhí)行的順序完全是按照我們預訂的順序來了,但以上代碼看著很別扭,需要層層嵌套,于是又發(fā)現(xiàn)了這種寫法:
復制代碼 代碼如下:
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");
});
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");
});
執(zhí)行結(jié)果的順序,也不相同:
復制代碼 代碼如下:
function
js/jquery-1.11.0.min.js: loaded
From jQuery
test.js: loaded
From test.js
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");
});
console.log("From test.js");
});
loadJs("js/jquery-1.11.0.min.js", function(){
console.log("From jQuery");
});
執(zhí)行結(jié)果也就不一樣,類似順序加載:
復制代碼 代碼如下:
undefined
test.js: loaded
From test.js
js/jquery-1.11.0.min.js: loaded
From jQuery
test.js: loaded
From test.js
js/jquery-1.11.0.min.js: loaded
From jQuery
希望本文所述對大家的javascript程序設(shè)計有所幫助。
您可能感興趣的文章:
- JavaScript動態(tài)添加css樣式和script標簽
- 動態(tài)創(chuàng)建script標簽實現(xiàn)跨域資源訪問的方法介紹
- Script標簽與訪問HTML頁面詳解
- javascript標簽在頁面中的位置探討
- script標簽屬性type與language使用選擇
- script標簽的 charset 屬性使用說明
- javascript 獲取url參數(shù)和script標簽中獲取url參數(shù)函數(shù)代碼
- asp.net(C#) 動態(tài)添加非ASP的標準html控件(如添加Script標簽)
- 有趣的script標簽用getAttribute方法來自腳本吧
- 淺談js script標簽中的預解析
相關(guān)文章
uniapp實現(xiàn)app檢查更新與升級詳解(uni-upgrade-center)
UniApp是一個跨平臺的開發(fā)框架,可以同時開發(fā)iOS和Android應(yīng)用,下面這篇文章主要給大家介紹了關(guān)于uniapp實現(xiàn)app檢查更新與升級(uni-upgrade-center)的相關(guān)資料,需要的朋友可以參考下2023-11-11
如何在現(xiàn)代JavaScript中編寫異步任務(wù)
這篇文章主要給大家介紹了關(guān)于如何在現(xiàn)代JavaScript中編寫異步任務(wù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01

