Javascript-向回调函数添加更多参数

Javascript-向回调函数添加更多参数,javascript,callback,asynccallback,Javascript,Callback,Asynccallback,我正在调用一个需要回调函数作为参数的异步函数 以下是javascript代码: for(i in array) { var item = array[i]; functionToCall(item[i][1], 50, function(a, b) { alert(a + b); }); } 我无法编辑函数调用函数。我想做的是像这样在回调函数中使用“item”变量 for(i in array) { var item = array[

我正在调用一个需要回调函数作为参数的异步函数

以下是javascript代码:

for(i in array) 
{
    var item = array[i];
    functionToCall(item[i][1], 50, function(a, b)
    {
        alert(a + b);
    });
}
我无法编辑函数调用函数。我想做的是像这样在回调函数中使用“item”变量

for(i in array) 
{
    var item = array[i];
    functionToCall(item[i][1], 50, function(a, b, c)
    {
        alert(a + b + c);
    }, item);
}
但是这个代码不能正常工作。我不能只在函数中使用“item”,因为它总是使用数组中的最后一个项


那么我该怎么做呢?

您可以在函数中使用
,但您需要“捕获”它,这样您就不会每次都使用数组的最后一个元素

for(var i = 0, l = array.length; i < l; ++i) { // better than for .. in
    var item = array[i];
    (function(item, i){
      functionToCall(item[i][1], 50, function(a, b) // do you really re-index item with the same index?
      {
          alert(a + b);
      });
    })(item, i);
}
for(var i=0,l=array.length;i
在中使用
for..来迭代数组是个坏主意。相反,使用
.forEach()
,您的许多问题就会迎刃而解:

array.forEach(function(item)
{ 
    functionToCall(item[1], 50, function(a, b) 
    { 
        alert(a + b + item[1]); 
    }); 
}

要在较旧的浏览器中使用
.forEach()
,我将尝试以下方法:

 function createExecutionCall(itemIndex, number, item)
 {
      return function() { functionToCall(itemIndex, number, function(a, b)
      {
           // Example, item should be contained within this closure then
           alert(a + b + item);
      });
 }

 for(i in array) 
 {
     var item = array[i];

     var call = createExecutionCall(item[i][1], 50, item);
     call();
  }

它的效果比预期的好,非常感谢!