promise简析
promise可以解決多個回調函數嵌套問題,將嵌套所表示的流程通過同步的代碼更加清晰的表達出來。
promise的用法與使用配置文件很類似:啟動異步函數,在then里面配置好異步函數成功或執行失敗的回調函數,然后就可以去干別的事了。
一個簡單示例的執行過程
一個簡單的示例如下:
var promise = new Promise(function(resolve, reject) {// 異步操作的代碼.....if (true){resolve("已解決");} else {reject("出錯了");}});promise.then(function(value){console.log(value);},function(error){console.log(error);});上面的代碼的時序圖大體如下:
其中:
client – 主程序,Async – 異步函數,Promise,ResolvedInvoke – resolved狀態回調函數,RejectedInvoke – rejected狀態回調函數,resolve – resolve函數
幾個關鍵過程說明如下:
(1.4 )調用異步函數Async之后,然后執行(1.5)會立即返回一個promise對象,然后主函數和異步函數同時往下執行。
(2.2) 指定promise的回調函數,主程序的任務完成,退出
(1.6)異步函數退出,調用resolve(),然后執行(1.7)改變promise的狀態
當promise狀態改變之后,執行(1.8)調用相應的回調函數。
所以,promise的執行過程大體如下:主程序創建promise并指定promise各種狀態下的回調函數,promise調用異步函數并保存異步函數的執行狀態,當異步函數退出時,可以調用resolve/reject改變promise的狀態,promise在狀態變化時調用相應的回調函數。
promise對象
promise保存著異步函數的執行狀態。
異步函數通過調用resolve/reject改變promise的狀態,主函數調用promise的then()方法指定promise在不同狀態下的回調函數。然后,主程序和異步程序可以各自往下執行,當promise狀態改變時,它會自動調用相應的回調函數。
也就是,主函數裝配promise,異步函數改變promise狀態,promise監聽自身變化,調用相應回調函數進行處理。
then
then函數指定promise的回調函數,可以鏈式操作,可以返回值,其返回值如果不是一個Promise對象,則直接作為下一個then的參數,否則進行返回的這個Promise的異步函數,根據執行結果繼續調用下一個then。
所以,只有在then里返回Promise的情況下,才能看出promise的厲害和用處。
作用
主要是解決多個回調函數的嵌套問題。下面例子就是兩個原本需要嵌套的回調函數,使用同步的方式表達出來。
var promise = doSomething(false);promise.then(function(value){console.log(value);return doSomethingElse(true);},function(error){console.log(error);return doSomethingElse(false);}).then(function(){console.log("成功后接著處理");},function(){console.log("出錯后接著處理");});function doSomething(param){//這里省略一些異步操作return new Promise(function(resolve, reject) {if (param){resolve("已解決");} else {reject("出錯了");}});}function doSomethingElse(param){//這里省略一些異步操作return new Promise(function(resolve, reject) {if (param){resolve();} else {reject();}});}總結
- 上一篇: RoboCode 参考代码
- 下一篇: SQl盲注原理及其简单演示