现在,这是一个有趣的问题.我有一个对象数组,如下所示:
objRequests = [
{
url: "/cgi-bin/script1.cgi",
dest: "#div1"
},
{
url: "/cgi-bin/script1.cgi",
dest: "#div2"
}
];
现在,我遍历这些对象以使用jQuery的$.getJSON()方法在特定地址从服务器加载一些信息,并且在通过回调函数进行了一些花哨的处理之后,需要将HTML放入其ID是通过“目标”指定的div中. .
通常,如果我需要指定额外的数据以进入回调,则可以使用匿名函数,这样就可以了.这里的问题在于,目的地的变量指针似乎保持不变,因此,在每个回调触发时,目的地始终等于“#div2”.
我尝试了以下方法:
for (var loop = 0; loop < objRequest.length; loop++)
{
var exec = new function(objResponse)
{
processResponse(objResponse, objRequest[loop].dest);
}
exec.dest == objRequest[loop].dest;
$.getJSON(objConfig.strTicketScript, exec);
}
以及
for (var loop = 0; loop < objRequest.length; loop++)
{
var destination = objRequest[loop].dest;
var exec = new function(objResponse)
{
processResponse(objResponse, destination);
}
exec.dest == objRequest[loop].dest;
$.getJSON(objConfig.strTicketScript, exec);
}
但由于某些原因,Firefox似乎仍未在匿名函数中创建单个数据.有没有办法在每次迭代中获得对数据的唯一引用?
解决方法:
您将需要进行关闭:
var exec = (function(dest){
return function(objResponse) {
processResponse(objResponse, dest);
}
})(objRequest[loop].dest);