JavaScript何时评估函数?是在页面加载还是函数被调用?JavaScript:JavaScript何时评估函数,onload或何时调用函数?
我之所以这么问是因为我有以下代码:
function scriptLoaded() {
// one of our scripts finished loading, detect which scripts are available:
var jQuery = window.jQuery;
var maps = window.google && google.maps;
if (maps && !requiresGmaps.called) {
requiresGmaps.called = true;
requiresGmaps();
}
if (jQuery && !requiresJQuery.called) {
requiresJQuery.called = true;
requiresJQuery();
}
if (maps && jQuery && !requiresBothJQueryGmaps.called) {
requiresBothJQueryGmaps.called = true;
requiresBothJQueryGmaps();
}
}
// asynch download of script
function addScript(url) {
var script = document.createElement('script');
script.src = url;
// older IE...
script.onreadystatechange=function() {
if (this.readyState == 'complete') scriptLoaded.call(this);
}
script.onload=scriptLoaded;
document.getElementsByTagName('head')[0].appendChild(script);
}
addScript('http://google.com/gmaps.js');
addScript('http://jquery.com/jquery.js');
// define some function dependecies
function requiresJQuery() { // create JQuery objects }
function requiresGmaps() { // create Google Maps object, etc }
function requiresBothJQueryGmaps() { ... }
我想要做的就是执行异步下载我的JavaScript,并在尽可能早的时间就开始执行这些脚本但是我的代码依赖于脚本被明显下载和加载的时间。
当我尝试上面的代码时,看起来我的浏览器仍然试图在我的require*
函数中计算代码,甚至在这些函数被调用之前。它是否正确?还是我误解我的代码有什么问题?
这个问题是唯一相关的是你是明智的把你的JavaScript从你的标记到外部文件。如果你缺乏这种智慧,那么你应该期待不确定和混乱。 – 2010-05-11 16:30:54