javascript - async 讀取文件
为情所困
为情所困 2017-05-19 10:46:58
0
2
686
async function a() {
    var result = await b()
    res.json(result)
}
var fse = require('fs-extra')

function b() {
    var fpath = '/data.json'
    // 异步读取文件
    fse.readJson(fpath, (err, data) => {
        if(err) console.log(err)
        return data
    })
}

上述程式碼中, resultundefined,也就是並沒有得到讀取檔案後的資料。我該怎麼修改,讓result 得到 data.json 的內容呢?

为情所困
为情所困

全部回覆(2)
PHPzhong

這種情況建議你使用stream 而且你的b函數並沒有回傳一個Promise 建議了解一下async/await和Promise之間的關係, 兩種處理方法

1.

var data = fs.createReadStream('/data.json')
data.pipe(res)

2.

function b () {
    var fpath = '/data.json'
    return new Promise((resolve, reject) =>{
        readJson(fpath, (err, data) => {
            if (err) reject(err)
            resolve(data)
        })
    })
}
给我你的怀抱
async function a() {
    var result = await b()
    res.json(result)
}
var fse = require('fs-extra')

function b() {
    var fpath = '/data.json'
    // 异步读取文件
    fse.readJson(fpath, (err, data) => {
        if(err) console.log(err)
        return data
    })
}

剛看到這個程式碼的時候我正在看一篇文章
6 Reasons Why JavaScript's Async/Await Blows Promises Away (Tutorial)
仔細想想你的函數b 使用了fse這個擴充功能來讀取檔案還是使用的回呼哈數。 (發展歷史是回呼函數->promise->Async/Await)。

也就是說async/Await不支援回呼函數的,如果一定要用a函數的async的話,可以改造b支援回傳一個promise。

var fse = require('fs-extra')
 async function a() {
    var result = await b();
    console.info(result);
}

 const b=  ()=> {
 let p= new Promise(function(resolve,reject){
      var fpath = 'data.json'
    // 异步读取文件
    fse.readJson(fpath,(err,data)=>{
        if(err){
            console.info(err);
            reject(err);
        }
        resolve(data);
    });
  });
    return p;
}
 
console .info(a());

使用Promise包裝之後就可以使用await的最新特性了。
剛學,請多指教

參考:
什麼是Promise
Node.js最新技術棧之Promise篇

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板