Jon*_*ter 7 javascript asynchronous
我有一些JSON数据如下:
{
version: 1,
partitions: {
'0': [ 1616133379 ],
'1': [ 1616133378 ],
'2': [ 1616133380 ]
}
}
Run Code Online (Sandbox Code Playgroud)
我使用async.each循环遍历数据,如下所示:
async.each(topicData.partitions, function(data, callback){
console.log('/brokers/topics/' + topic + '/partitions/' + data + '/state');
callback();
},
function(err){
if(err) {
console.log(err);
callback(err);
}
});
Run Code Online (Sandbox Code Playgroud)
我得到的输出是:
'/ brokers/topics/testing/partitions/1616133379/state''/ brokers/topics/testing/partitions/1616133378/state''/ brokers/topics/testing/partitions/1616133380/state'
正如您所看到的,data通过async.each函数传递的项目保持键/值对的值,而我实际上希望它传递键以产生此输出:
'/ brokers/topics/testing/partitions/0/state''/ brokers/topics/testing/partitions/1/state''/ broker/topics/testing/partitions/2/state'
无论如何我可以获得传递的密钥而不是价值吗?
这必须异步运行.
谢谢
您可以使用forEachOf,迭代器会在对象的情况下传递每个项的值和键.
iterator(item,key,callback) - 一个应用于obj中每个项目的函数.键是项的键,或者是数组的索引.迭代器传递一个回调(err),一旦完成就必须调用它.如果没有发生错误,则应该在没有参数或显式null参数的情况下运行回调.
用法:
async.forEachOf(topicData.partitions, function(item, key, callback){
console.log('/brokers/topics/' + topic + '/partitions/' + key + '/state');
callback();
}, function(err){
if(err) {
console.log(err);
callback(err);
}
});
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6525 次 |
| 最近记录: |