在日常的前端开发中,偶尔有需要动态插入javascript代码的需求,基本思路是:
1、动态创建一个script标签,设置其src属性,type属性等
2、将script节点插入页面,加载js文件
即相当于将添加到了页面,只不过这个过程是动态完成的,为此特意封装了一个函数来实现:
复制代码 代码如下:
// 动态插入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');
});