我们在写js的时候经常要动态加载一段js脚本,比如下面这种代码var js = document.createElement('script');
js.type = 'text/javascript';
js.async = true;
js.src = 'http://example.com/static.js';var s = document.getElementsByTagName('script')[0];
s.parentNode.insertBefore(js, s);而且http://example.com/static.js里的内容是我完全不能控制的,也就是不能在里面加个回调callback来表示加载完成,大家有什么思路吗?
2 回答
慕尼黑8549860
TA贡献1818条经验 获得超11个赞
function Script(callback){ var js = document.createElement("script"); this.js = js; js.setAttribute("type",'text/javascript'); var head = document.getElementsByTagName('head')[0]; head.appendChild(js); if(navigator.appName.toLowerCase().indexOf('netscape') == -1){ js.onreadystatechange = function(){ if(js.readyState == 'complete'){ callback(js); } } }else{ js.onload = function(){ callback(js); } } } Script.prototype.get = function(url){ this.js.src = url; } function script_onload(script){ alert(script.src); } var load_js = new Script(script_onload); load_js.get('http://static.gongju.com/js/jquery-1.4.4.min.js');
添加回答
举报
0/150
提交
取消