1

像这样的代码:

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对象写入文件。如何等待所有异步函数完成?

或者还有其他方法可以做到这一点吗?

4

1 回答 1

3

你可以像这样手动完成

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)

请注意我没有测试过这个。

于 2013-02-08T14:16:25.457 回答