async.map的签名是map(arr,iterator,callback)(https://github.com/caolan/async#map)
我有var context //object
我需要将它传递给迭代器。我该怎么做?
答案 0 :(得分:23)
您可以通过两种方式使用bind:
iterator.bind(context)
这将使context
在迭代器函数中可用this
。
另一种方法是创建部分功能:
iterator.bind(null, context)
这将使context
可用作迭代器函数的第一个参数。因此,迭代器签名不是iterator(item, callback)
,而是iterator(context, item, callback)
。
简单演示:
// first:
async.map([1, 2, 3], function(item, callback) {
callback(null, item * this.mult);
}.bind({ mult: 5 }), function(err, results) {
console.log('R', results);
});
// second:
async.map([1, 2, 3], function(ctx, item, callback) {
callback(null, item * ctx.mult);
}.bind(null, { mult: 5 }), function(err, results) {
console.log('R', results);
});
答案 1 :(得分:0)
使用箭头功能,您可以调整功能并传入额外的参数:
async.map([1,2,3], context => (item, callback) => {
// you now have access to context, item, and callback here
}, (err, results)=>{
// async.map callback function
});
我喜欢将我的函数放在异步函数之外以保持干净:
const processItem = context => (item, callback) => {
// process items here
};
async.map([1,2,3], processItem(context)(item, callback), (err, results)=>{
// async.map callback function
});
答案 2 :(得分:0)
使用箭头功能,最佳做法是使用async.apply。 async.apply提供了添加额外参数的功能,这些参数将作为第一个参数传递给目标函数。这是一个示例代码:
processItemFuction(context, item, callback) {
//Here you can access context as well
}
async.map([1,2,3]), async.apply(processItemFuction, context), (err, res) {
// async.map callback function
}