JavaScript:将更改参数传递给回调

时间:2010-06-22 21:04:13

标签: javascript loops callback anonymous-function

现在这是一个有趣的问题。我有一个对象数组如下:

objRequests = [
   {
      url: "/cgi-bin/script1.cgi",
      dest: "#div1"
   },
   {
      url: "/cgi-bin/script1.cgi",
      dest: "#div2"
   }
];

现在,我遍历这些对象,使用jQuery的$ .getJSON()方法从特定地址的服务器加载一些信息,并在通过回调函数进行一些花哨的修改后,需要将HTML放入通过回调函数指定id的div中'DEST'。

通常情况下,如果我需要指定额外的数据进入回调,我会使用匿名函数,这样就可以了。这里的问题是目标的变量指针似乎保持不变,所以当每次回调触发时,目标总是等于“#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似乎仍未在匿名函数中创建单个数据。有没有办法在每次迭代中获得对数据的唯一引用?

1 个答案:

答案 0 :(得分:3)

你需要做一个关闭:

var exec = (function(dest){
  return function(objResponse) {
     processResponse(objResponse, dest);
  }
 })(objRequest[loop].dest);