亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

簡單實現異步編程promise模式

2019-11-20 11:56:49
字體:
來源:轉載
供稿:網友

異步編程
javascript異步編程, web2.0時代比較熱門的編程方式,我們平時碼的時候也或多或少用到,最典型的就是異步ajax,發送異步請求,綁定回調函數,請求響應之后調用指定的回調函數,沒有阻塞其他代碼的執行。還有像setTimeout方法同樣也是異步執行回調的方法。

如果對異步編程還不太熟悉的話,直接戳 阮一峰大牛的教程 ,這篇文章介紹了四種異步編程的方式:

  1. 回調函數
  2. 事件監聽
  3. 發布/訂閱
  4. promise模式

這幾種方式的可維護性逐級遞增,理解難度也逐級遞增。這篇總結也是針對promise模式的。

promise模式
那么多中異步編程的方式,為什么選擇promise, 因為前面幾種方式不夠靈活,用起來不夠痛快,不優雅。為了降低異步編程的復雜性,所以promise。

promise的核心是有一個promise對象,這個對象有一個重要的then()方法, 它用于指定回調函數,如:

f1().then(f2);

promise模式在任何時刻都有三種狀態:已完成(resolved),未完成(unfulfilled),那么then()方法就是為狀態變化指定不同的回調函數,并總是返回一個promise對象,方便鏈式調用。

那promise模式下,返回的數據如何在各個回調函數之間傳播呢,通過resolve方法,你可以將一個函數的返回值作為參數傳遞給另一個函數,并且將另一個函數的返回值作為參數再傳遞給下一個函數……像一條“鏈”一樣無限的這么做下去。

代碼實現
通過創建一個Promise構造函數來實現promise模式:

//constructorvar Promise = function() { this.callbacks = [];}Promise.prototype = { construct: Promise, resolve: function(result) {  this.complete("resolve", result); }, reject: function(result) {  this.complete("reject", result); }, complete: function(type, result) {  while (this.callbacks[0]) {   this.callbacks.shift()[type](result);  } }, then: function(successHandler, failedHandler) {  this.callbacks.push({   resolve: successHandler,   reject: failedHandler  });  return this; }}// testvar promise = new Promise();var delay1 = function() { setTimeout(function() {  promise.resolve('數據1'); }, 1000); return promise;};var callback1 = function(re) { re = re + '數據2'; console.log(re);};delay1().then(callback1)

代碼分析
我們可看到一個簡單的promise對象的構造函數的結構:

  • callbacks: 用于管理回調函數
  • resolve: 請求成功時執行的方法
  • reject:請求失敗時執行的方法
  • complete: 執行回調
  • then:綁定回調函數

測試:

var promise = new Promise();var delay1 = function() { setTimeout(function() {  promise.resolve('數據1'); }, 1000); return promise;};var callback1 = function(re) { re = re + '數據2'; console.log(re); promise.resolve(re);};var callback2 = function(re) { console.log(re + '數據3');};delay1().then(callback1).then(callback2);

結果:

一秒之后輸出:

分析:

//第一步var delay1 = function() { setTimeout(function() {  promise.resolve('數據1'); }, 1000); return promise;};

這個函數通過setTimeout方法,異步傳遞一個數據1,并返回一個promise對象(必須)。

//第二步var callback1 = function(re) {  re = re + '數據2'; console.log(re); promise.resolve(re);};

callback1和callback2都是要通過then方法注冊的回調函數,其中callback1通過resolve方法把數據往下傳遞。

//第三步delay1().then(callback1).then(callback2);

delay1()方法執行完,因為返回了一個promise對象,所以可以再調用then()方法為delay1()的setTimeout異步執行操作指定回調函數, 又因為then()方法也返回的是promise對象,所以還可以再調用then方法

//第四步setTimeout(function() { promise.resolve('數據1');}, 1000);

一秒之后,當其他代碼執行完成,開始執行異步代碼promise.resolve('數據1');,這里調用promise的resolve()方法,指定了一個成功狀態,并把數據1作為參數。

//第五步resolve: function(result) { this.complete("resolve", result);},//第六步:循環執行回調,將上一個回調的結果傳遞給下一個回調complete: function(type, result) { while (this.callbacks[0]) {  this.callbacks.shift()[type](result); }},

這其中比較難理解的就是第五,六步。

以上就是本文的全部內容,希望對大家的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产亚洲精品久久| 亚洲免费视频在线观看| 久久精品国产精品亚洲| 亚洲精品720p| 中文字幕九色91在线| 成人网在线观看| 成人xxxx视频| 欧美伊久线香蕉线新在线| 欧美精品videos性欧美| 日韩在线视频线视频免费网站| 91精品国产色综合久久不卡98口| 精品日韩美女的视频高清| 国产成人在线视频| 日韩黄色av网站| 久久露脸国产精品| 欧洲午夜精品久久久| 中文字幕综合一区| 精品视频中文字幕| 欧美日韩国产成人在线| 91精品国产777在线观看| 亚洲男人第一av网站| 欧洲成人午夜免费大片| 国产中文日韩欧美| 欧美高清第一页| 精品久久久久久久久中文字幕| 久久久久久久久久久免费精品| 精品国产自在精品国产浪潮| 欧美激情视频一区二区三区不卡| 国产精品精品久久久久久| 欧美大人香蕉在线| 亚洲精品久久视频| 日韩在线欧美在线| 欧美福利在线观看| 久久久免费精品| 亚洲电影免费观看高清完整版在线观看| 国产亚洲精品久久久久久777| 欧美色欧美亚洲高清在线视频| 一区二区三区视频免费在线观看| 97在线精品视频| 精品人伦一区二区三区蜜桃免费| 亚洲欧洲日产国码av系列天堂| 激情久久av一区av二区av三区| 亚洲最大福利网| 亚洲欧美日韩在线一区| 一区二区三区高清国产| 最近免费中文字幕视频2019| 欧美成人h版在线观看| 亚洲精品456在线播放狼人| 国产97色在线| 亚洲欧美日韩图片| 欧美第一黄网免费网站| 日韩欧美中文字幕在线播放| 久久99精品国产99久久6尤物| 久久久亚洲精品视频| 色播久久人人爽人人爽人人片视av| 亚洲福利在线播放| 欧美性生活大片免费观看网址| 精品国产乱码久久久久久婷婷| 久久久久久久久久av| 日韩大片免费观看视频播放| 91国偷自产一区二区三区的观看方式| 亚洲网站在线播放| 日本精品久久电影| 国产精品一香蕉国产线看观看| 亚洲高清久久网| 欧美性色xo影院| 亚洲色图校园春色| 国产成人精品电影久久久| 91精品国产91久久久久久吃药| 欧美日韩激情视频| 成人黄色免费在线观看| 日韩久久午夜影院| 欧美日韩激情美女| 欧美洲成人男女午夜视频| 在线电影av不卡网址| 日韩中文字幕第一页| 国内自拍欧美激情| 国产成人+综合亚洲+天堂| 国产啪精品视频网站| 国产亚洲精品美女久久久| 热久久美女精品天天吊色| 国产精品成人国产乱一区| 亚洲欧美日韩一区在线| 国产精品成人一区二区三区吃奶| 欧美激情小视频| 中文欧美在线视频| 在线成人激情黄色| xvideos亚洲| 成人性生交大片免费看视频直播| 久久久精品免费| 久久夜色精品亚洲噜噜国产mv| 色偷偷888欧美精品久久久| 亚洲伊人一本大道中文字幕| 成人啪啪免费看| 欧美精品一区二区三区国产精品| 亚洲片在线观看| 国产美女91呻吟求| 欧美性xxxx极品高清hd直播| 亚洲色无码播放| 精品丝袜一区二区三区| 欧美亚洲国产视频| 亚洲美女av在线| 自拍视频国产精品| 亚洲一区二区三区xxx视频| 欧美国产日韩视频| 亚洲精品一二区| 欧美日韩综合视频| 欧美专区在线视频| 成人h片在线播放免费网站| 久久综合伊人77777蜜臀| 91黑丝高跟在线| 国产一区二区在线免费| 亚洲第一av网站| 91精品国产乱码久久久久久蜜臀| 国产男女猛烈无遮挡91| 欧美性猛交xxxx偷拍洗澡| 国产黑人绿帽在线第一区| 尤物九九久久国产精品的分类| 538国产精品一区二区在线| 亚洲精品视频免费在线观看| 精品一区二区电影| 国产精品久久久久久亚洲影视| 国产亚洲精品久久久久久777| 国产精品444| 最新国产成人av网站网址麻豆| 久久影院资源站| 91精品国产91久久久久久最新| 亚洲自拍偷拍网址| 97久久精品国产| 国产在线精品播放| 午夜精品久久久久久99热软件| 国产91在线播放九色快色| 性色av一区二区三区| 亚洲国产古装精品网站| 91精品久久久久久久久久久久久| 国产精品爱久久久久久久| 亚洲白虎美女被爆操| xvideos国产精品| 亚洲高清色综合| 国产精品视频午夜| 亚洲图片欧洲图片av| 国语自产偷拍精品视频偷| 精品在线欧美视频| 欧美高清在线播放| 性视频1819p久久| 中文字幕亚洲无线码在线一区| 欧美在线观看一区二区三区| 日韩中文字幕在线视频| 国产日韩欧美在线视频观看| 久久亚洲精品网站| 亚洲精品福利视频| 亚洲欧洲激情在线| 亚洲二区在线播放视频| 色狠狠av一区二区三区香蕉蜜桃| 亚洲国内精品在线| 久久久av网站| 国产亚洲视频中文字幕视频| 清纯唯美亚洲激情| 久久亚洲精品中文字幕冲田杏梨| 欧美日韩亚洲一区二| 欧美亚洲伦理www| 欧美专区在线观看| 成人免费大片黄在线播放| 亚洲欧洲一区二区三区在线观看|