Javascript-向回调函数添加更多参数
我正在调用一个需要回调函数作为参数的异步函数 以下是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[
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();
}
它的效果比预期的好,非常感谢!