認識並使用 Promise

1、瞭解 Promise:

Promise 是一個異步操做返回的對象,用來傳遞異步操做的消息。

能夠解決的問題:

  1. 解決了回調地獄問題,不會致使難以維護;
  2. 合併多個異步請求,節約時間。

Promise 有三種狀態:

  1. Pending Promise 對象實例建立時的初始態;
  2. Fulfilled 成功時的狀態;
  3. Rejected 失敗時的狀態。

2、使用 Promise:

Promise.then():用來指定 Promise 對象的狀態改變時要執行的操做。

let promise = new Promise(function (resolve, reject) {
    resolve('成功');
    //reject('失敗');
})

promise.then(function (data) {
    console.log('data: ', data);
},function (err) {
    console.log('err: ', err);
})
複製代碼

Promise.all():接收一個數組,數組內是 Promise 實例,必須都成功呢才表示成功。

Promise.race():接收一個數組,數組內是 Promise 實例,最先返回的對象成功了,就變爲成功態,若是失敗了,就改變狀態爲失敗態。

let fs = require('fs');
function read(url){
    return new Promise(function(resolve, reject){
        fs.readFile(url,'utf8',function(err, data){
            if(err) reject( err);
            resolve( data);
        })
    })
}

Promise.all([read('1.txt'), read('2.txt')]).then(function (data) {
    console.log(data);
},function (err) {
    console.log('err: ', err);
})

Promise.race([read('1.txt'), read('2.txt')]).then(function (data) {
    console.log(data);
},function (err) {
    console.log('err: ', err);
})
複製代碼

Promise.resolve():返回一個 Promise 實例,這個 Promise 實例處於 resolve 狀態。

Promise.resolve([1,2,3]).then(function(data){
    console.log(data);
});
複製代碼

輸出:[ 1, 2, 3 ]數組

Promise.reject():返回一個 Promise 實例,這個 Promise 實例處於 reject 狀態。

Promise.reject([1,2,3]).then(null,function(err){
    console.log('err',err)
});
複製代碼

輸出:err [ 1, 2, 3 ]promise

相關文章
相關標籤/搜索