像这样的代码:
fileArray = ['a.json','b.json','c.json']
dict = {}
fileArray.map (f) ->
fs.readFile f, (err, data) ->
json.parse data, (k, v) ->
dict[k] = v
我想将dict
对象写入文件。如何等待所有异步函数完成?
或者还有其他方法可以做到这一点吗?
像这样的代码:
fileArray = ['a.json','b.json','c.json']
dict = {}
fileArray.map (f) ->
fs.readFile f, (err, data) ->
json.parse data, (k, v) ->
dict[k] = v
我想将dict
对象写入文件。如何等待所有异步函数完成?
或者还有其他方法可以做到这一点吗?
你可以像这样手动完成
fileArray = ['a.json','b.json','c.json']
dict = {}
counter = 0
fileArray.map (f) ->
fs.readFile f, (err, data) ->
counter +=1
json.parse data, (k, v) ->
dict[k] = v
if counter >= fileArray.length
fs.writeFile("mydict.txt", dict.toString())
或者您使用异步库(例如https://github.com/caolan/async)
fileArray = ['a.json','b.json','c.json']
dict = {}
counter = 0
read = (file)->
fs.readFile f, (err, data) ->
json.parse data, (k, v) ->
dict[k] = v
fns = ((do (file) -> read(file)) for file in fileArray)
#use the async lib
async.parallel fns, -> fs.writeFile "mydict.txt", json.stringify(dict)
请注意我没有测试过这个。