我正在使用 caolan's async.js .我很困惑为什么在所有迭代器完成之前调用回调。当我运行以下代码时:
async.filter(matched_objects.fields, function(item, callback) {
console.log('checking field: ' + item.id);
if(item.id == 130 || item.id == 131) {
console.log('calling field true: ' + item.id);
callback(true);
}
callback(false);
},
function(fieldResults) {
console.log('fieldsResults.length=' + fieldResults.length);
});
我得到以下输出:
checking field: 130
calling field true: 130
fieldsResults.length=1
checking field: 131
calling field true: 131
在过滤器循环中检查第二个 results.fields
项之前调用回调中的 console.log 对我来说没有任何意义。
最佳答案
问题是 callback(false)
每次都会被调用,即使您遇到了 if
条件。正确的方法是添加一个 return
语句:
if(item.id == 130 || item.id == 131) {
console.log('calling field true: ' + item.id);
return callback(true); // now you won't call callback(false) everytime
}
callback(false);
你甚至可以通过说来缩短过滤器:
callback(item.id == 130 || item.id == 131);
关于javascript - async.filter 在所有迭代器完成之前调用回调,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14345159/