1.解決回呼地獄
例如我們經常可能需要非同步請求一個資料之後作為下一個非同步操作的入參getData(function(a){ getMoreData(a, function(b){ getMoreData(b, function(c){ getMoreData(c, function(d){ getMoreData(d, function(e){ ... }); }); }); }); });可以發現上面的程式碼看起來是非常可怕的,層層嵌套,如果在加上複雜的邏輯判斷,程式碼可讀性會變得非常差。
但是你如果使用promise的話:
function getData() { return new Promise(function (resolve, reject) { resolve(1); }); } function getMoreData(arg) { return new Promise(function (resolve, reject) { resolve(arg + 10); }); } getData().then(function (a) { console.log(a); // 1 return getMoreData(a); }).then(function (b) { console.log(b); // 11 })把上面程式碼再簡潔點兒
getData() .then(a => getMoreData(a)) .then(b => console.log(b));2.promise 可以實現在多個請求發送完成後,再得到或處理某個結果
// 两个数据都回来之后再进行操作 let fs = require('fs'); fs.readFile('./1.txt', 'utf8', function (err, data) { console.log(data); }) fs.readFile('./2.txt', 'utf8', function (err, data) { console.log(data); })使用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(data=>{ console.log(data); },err=>{ console.log(err); });二、promise原理實作
#1.最簡單的實作
基於上面的應用程式場景發現promise可以有三種狀態,分別是pedding 、Fulfilled、 Rejected。 Pending Promise物件實例建立時候的初始狀態
Fulfilled 可以理解為成功的狀態Rejected可以理解為失敗的狀態###·######建構一個Promise實例需要給Promise建構子傳入一個函式。傳入的函數需要有兩個形參,兩個形參都是function類型的參數。分別是resolve和reject。 ############·######Promise上還有then方法,then 方法就是用來指定Promise 物件的狀態改變時決定執行的操作,resolve 時執行第一個函數(onFulfilled),reject時執行第二個函數(onRejected)################·######當狀態變成resolve時便不能再變成reject,反之同理。 ######基於上面描述我們可以實現一個這樣的promise###function Promise(executor){ //executor执行器 let self = this; self.status = 'pending'; //等待态 self.value = undefined; // 表示当前成功的值 self.reason = undefined; // 表示是失败的值 function resolve(value){ // 成功的方法 if(self.status === 'pending'){ self.status = 'resolved'; self.value = value; } } function reject(reason){ //失败的方法 if(self.status === 'pending'){ self.status = 'rejected'; self.reason = reason; } } executor(resolve,reject); } Promise.prototype.then = function(onFufiled,onRejected){ let self = this; if(self.status === 'resolved'){ onFufiled(self.value); } if(self.status === 'rejected'){ onRejected(self.reason); } } module.exports = Promise;###更多###常見問題###,敬請訪問PHP中文網。 ###
以上是promise原理是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!