在日常的前端開發中,偶爾有需要動態插入javascript代碼的需求,基本思路是:
1、動態創建一個script標簽,設置其src屬性,type屬性等
2、將script節點插入頁面,加載js文件
即相當于將<script type="text/javascript" src="xxx.js"></script>添加到了頁面,只不過這個過程是動態完成的,為此特意封裝了一個函數來實現:
復制代碼 代碼如下:
// 動態插入script標簽
function createScript(url, callback){
var oScript = document.createElement('script');
oScript.type = 'text/javascript';
oScript.async = true;
oScript.src = url;
/*
** script標簽的onload和onreadystatechange事件
** IE6/7/8支持onreadystatechange事件
** IE9/10支持onreadystatechange和onload事件
** Firefox/Chrome/Opera支持onload事件
*/
// 判斷IE8及以下瀏覽器
var isIE = !-[1,];
if(isIE){
alert('IE')
oScript.onreadystatechange = function(){
if(this.readyState == 'loaded' || this.readyState == 'complete'){
callback();
}
}
} else {
// IE9及以上瀏覽器,Firefox,Chrome,Opera
oScript.onload = function(){
callback();
}
}
document.body.appendChild(oScript);
}
復制代碼 代碼如下:
createScript('xxx.js', function(){
console.log('OK');
});
新聞熱點
疑難解答
圖片精選