-2

在单个函数中,我想使用 xmlhttprequests 下载三个资源;当它们被加载时,我想使用上述请求的响应调用一个函数。但是,当我尝试调用该函数时,所需的上述响应是未定义的。

function(){
var File=null
var Meta=null
var Engine=null
var xhrFile = new XMLHttpRequest()
var xhrMeta = new XMLHttpRequest();
var xhrEngine = new XMLHttpRequest();
xhrFile.open('GET','/archive/file.txt',true)
xhrMeta.open('GET','/template/file.js',true)
xhrEngine.open('GET','/javascript/app/hemp/engine.js',true)
xhrFile.responseType='arraybuffer';
xhrMeta.responseType='text';
xhrEngine.responseType='text';
xhrFile.onload = function(){File=xhrFile.response}
xhrMeta.onload = function(){File=eval(xhrMeta.response)}    
xhrEngine.onload = function(){Engine=eval(xhrEngine.response)}
xhrFile.send();
xhrMeta.send();
xhrEngine.send();
var DDM=Engine({'file':File,'meta':Meta}) 
return DDM
};

该代码不起作用,需要一些改造!

4

2 回答 2

0

最后一部分: var DDM=Engine({'file':File,'meta':Meta}) return DDM

将始终产生 undefined,因为此时可能尚未为FileMeta分配任何内容,因为 XMLHttpRequests 可能尚未返回。换句话说,他们的 .onload() 函数还没有被调用,因此 File/Meta 还没有被定义。

您要做的是在 onload() 中检查 File 和/或 Meta 以查看它们是否已定义(也就是它们的 XMLHttpRequests 已成功返回)。如果是,那么您可以调用 Engine({'file':File, 'meta': Meta}) 因为此时它们存在。

于 2013-03-06T08:54:23.900 回答
0

我解决了......这并不难......只是一点点想象力

var solve = function(File,Meta,Engine){
    var DDM=Engine({'file':File,'meta':Meta});
    return DDM;
};


//code added to the onload listeners 
xhrFile.onload = function(){
    File=xhrFile.response;
    if (File && Meta && Engine){
        return solve(File,Meta,Engine);
    }
};
xhrMeta.onload = function(){
    Meta=eval(xhrMeta.response);
    if (File && Meta && Engine){
        return solve(File,Meta,Engine);
    }
};
xhrEngine.onload = function(){
    Engine=eval(xhrEngine.response);
    if (File && Meta && Engine){
        return solve(File,Meta,Engine);
    }
};
于 2013-03-06T08:57:18.123 回答