使用Promise避免陷入callback回調地獄

使用單個promise的情形

//index.js
new Promise(
    (resolve, reject) => {
        fs.readFile('logger.js', (err, data) => { 
            if (err) {
                reject(err)
            } else {
                resolve(data)
            }
        })
    }
).then(data => {
    console.log(data.toString())
}).catch(err => {
    console.log(err)
})

//logger.js
//把logger.js和index.js放在同一目錄下即可

如果想讀取多個文件 並且避免使用callback回調

//index.js
fs = require('fs')
util = require('util')

var read = util.promisify(fs.readFile)

Promise.all([
    read('logger1.js'),
    read('logger2.js'),
    read('logger3.js')
    ]
).then(data => {
    const [data1, data2, data3] = data
    console.log(data1.toString())
    console.log(data2.toString())
    console.log(data3.toString())
}).catch(err => {
    console.log(err)
})

// 注 logger1.js, logger2.js, logger3.js 和 index.js 需在同一目錄下
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章