动态脚本加载的最佳方式
best way of dynamic script loading
我需要动态和顺序地加载一些js文件(即:第一个脚本加载完成后再加载第二个脚本,第二个脚本加载完成后再加载第三个脚本,依此类推)。
问题:如何检测何时脚本已加载?我遇到了onload事件的问题——它在IE8中不会触发。看完这篇文章后,我尝试订阅onreadystatechange,并编写了非常难看的代码来加载脚本:
function loadScript(url, callback) {
var isLoaded = false;
var script = document.createElement('script');
script.onreadystatechange = function () {
if ((script.readyState == 'complete' || script.readyState == 'loaded') && !isLoaded) {
if (callback) callback();
}
};
script.setAttribute('type', 'text/javascript');
script.setAttribute('src', url);
document.head.appendChild(script);
};
你能建议更好的跨浏览器解决方案吗?
乌利希期刊指南:谢谢你的回答。如果我还需要加载jquery.js(例如,客户端有旧版本),我该怎么办?
我认为你需要的是jQuery。getScript
这个函数接受一个URL和一个成功方法,你可以用它来链接加载脚本,从而依次加载它们:
jQuery.getScript( url, function() {
jQuery.getScript( url2, function()
{/*... all 2 scripts finished loading */}
);
});
下面是我使用jQuery.getScript();
加载几个脚本的代码片段function getScripts(inserts, callback)
{
var nextInsert = inserts.shift();
if (nextInsert != undefined)
{
console.log("calling"+nextInsert);
jQuery.getScript(nextInsert, function(){ getScripts(inserts, callback); })
.fail(function(jqxhr, settings, exception){alert("including "+nextInsert+" failed:'n" +exception)});
}
else
{
if (callback != undefined) callback();
}
};
用法:
var includes = [
"js/script1.js",
"js/script2.js",
"js/script3.js"
];
getScripts(includes, function(){ /* typically a call to your init method comes here */; });
RequireJS:
…是一个JavaScript文件和模块加载器。它针对浏览器内使用进行了优化,但也可以在Rhino和Node等其他JavaScript环境中使用。使用像RequireJS这样的模块化脚本加载器可以提高代码的速度和质量。
表示它兼容IE 6+, Firefox2 +, Safari 3.2+, Chrome 3+和Opera 10+。
相关文章:
- 在localhost Dev Box上测试JSONP请求的最佳方式
- 为react组件传递道具的最佳方式
- 让Webpack管理Quirky AMD定义的最佳方式
- 在承诺链中处理早期回报的最佳方式
- 在ng重复循环中显示条件内容的最佳方式是什么
- 在phonegap中为android调用onload函数的最佳方式
- 链接两个网页或网络应用程序的最佳方式
- 什么's是连接供应商js文件的最佳方式
- 什么's是在javascript中迭代项的最佳方式
- 在node.js中编写单元测试的最佳方式是什么
- 在页面上记录数据并实现pushstate()的最佳方式
- 使用AJAX在Rails中提交动态表单的最佳方式是什么
- 什么'这是加载jQuery的最佳方式
- 将大数组(字符串和类型数组的混合物)存储到blob或文件中/从blob或文件检索大数组的最佳方式
- 在网站上显示.mov作为加载屏幕的最佳方式
- 使用Angular存储用户以前是否选中过复选框,然后再调用它的最佳方式是什么
- 以角度渲染表中数据的最佳方式
- 删除集合中旧邮件/帖子的最佳方式
- 显示全屏Ajax加载程序的最佳方式
- PHP和JS中表单验证的最佳方式