黄视频网站在线免费观看-黄视频网站在线看-黄视频网站在线观看-黄视频网站免费看-黄视频网站免费观看-黄视频网站免费

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 如何講清楚Promise?

如何講清楚Promise?

來源:千鋒教育
發布人:qyf
時間: 2022-10-10 16:06:43 1665389203

如何講清楚Promise

  此文章主要講解核心思想和基本用法,想要了解更多細節全面的使用方式,請閱讀官方API

  這篇文章假定你具備最基本的異步編程知識,例如知道什么是回調,知道什么是鏈式調用,同時具備最基本的單詞量,例如page、user、promise、then、resovle、reject、pay、fix、order等等,如果你對這些單詞非常陌生,那么你需要先花點時間補充一下你的英語。

  什么是異步操作?

  所謂異步操作,指的是可以跟當前程序同時執行的操作。舉例:

  $("#page").scrolltop(0 ,1000); //使用1秒鐘時間將頁面滾動至頂部

  $("#nav-float").hide (1000); //使用1秒鐘時間將懸浮導航欄隱藏

  只要你稍微有點異步編程經驗,就應該知道,這兩個方法會同時完成。

  它們的編寫順序并不會影響它們的執行順序

  //異步操作的特點就是,不會打斷當前程序的執行

  //getUsers請求發出后,會立刻向下繼續執行第二個請求

  ajax("/getUsers",function(data) {

  //回掉函數會在請求成功后調用

  })

  //resumelist請求會立刻開始,無論getUsers是否結束

  ajax("/resumelist", function(data) {

  })

  //至于哪一個ajax先返回結果并執行回調函數,從代碼的編寫順序上是無法確定的。

  我們可以給異步操作做一個簡單的定義

  當一個操作開始執行后,主程序無需等待它的完成,可以繼續向下執行。此時該操作可以跟主程序同時(并發)執行。這種操作我們就稱之為異步操作。 通常當操作完成時,會執行一個我們事先設定好的回調函數來做后續的處理。

  我們常見的異步操作例如:

  · 添加定時器 setTimeout/setInterval

  · 執行某個動畫 animate

  · 發起網絡請求 request

  異步會帶來什么問題?

  比如我們現在有兩個動畫,需要按順序來執行,也就是第一個結束,第二個才能開始

  這個時候可能有點麻煩,傳統的解決方法是通過回調:

  animateA(function( ){

  animateB( );

  })

  這種方案顯然不太好,如果有很多異步操作需要順序執行,就會產生所謂的“回調地獄”

  ajaxA(function( ){

  ajaxB(function( ){

  ajaxC(function( ){

  ajaxD(function( ){

  ......

  });

  });

  });

  })

  這種代碼不管是寫起來還是讀起來都比較煩人。

  我們來看下經過Promise改造后的樣子(偽代碼)

  new Promise(ajaxA)

  .then(ajaxB)

  .then(ajaxC)

  .then(ajaxD);

  Promise的使用及原理

  要熟練Promise的的使用,你必須要先搞懂它解決問題的原理

  貼一段實際的Promise代碼,你來感受一下先:

  newPromise(resolve=>{

  ajax("/pay/post", data=>resolve() );

  }).then(resolve=>{

  ajax("/order/fix", data=>{

  //處理數據

  })

  })

  上面的代碼使用了ES6的箭頭函數,雖然大大簡化了代碼的寫法,

  但對于初級程序猿來講極不友好

  讀這種代碼簡直跟讀金剛經差不多。

  我們把代碼還原成ES5的樣子

  new Promise(function(resolve){

  ajax("/pay/post",function(data){

  resolve();

  })

  }).then(function(){

  ajax("/order/fix",function(data){

  })

  })

  接下來,我們就按照費曼技巧來一步步的學習Promise是如何解決問題的

  問題1, 作為一個異步函數,尤其像ajax這種網絡請求,連我自己都不能確定函數的執行時間,Promise是怎么知道第一個函數什么時候結束的? 然后再開始執行下一個?

  Promise并沒有那么神奇,它并不能知道我們的函數什么時候結束,

  你注意到上面代碼中的第3行了嗎

  在ajax請求結束執行回調的時候,

  我們調用了一個resolve()函數,這句代碼非常的關鍵.

  這其實就是在通知Promise,當前這個函數結束啦,

  你可以開始執行下一個。 這時Promise就會去執行then里面的函數了。

  問題2, 所以按照你的意思,如果我不調用這個方法,Promise就不知道這個函數有沒有結束,那么then里面的函數就不會執行,也就是說我的第二個請求就永遠不會發送了唄?

  Bingo!! 恭喜你已經學會了邏輯推理+搶答。

  問題3, 可是這個resolve函數是從哪來的? 需要我自己定義嗎? 從代碼上看它好像是個參數,那又是誰傳入函數中的?

  你得先弄明白Promise的基本結構

  new Promise(函數1).then(函數2);

  我們把函數1和函數2都以參數形式傳給了一個Promise對象,

  所以接下來函數1和2都會由這個Promise對象控制,

  簡單的說,函數1和函數2都會由Promise對象來執行。

  所以在函數1執行時,參數也當然是由Promise對象傳遞進去的。

  new Promise(function(resolve){

  //resolve是Promise對象在調用函數時傳入的參數

  }).then(函數2);

  問題4, Promise對象為啥要在執行第1個任務的時候,把這個resolve函數 傳進來,有什么目的?

  Promise對象沒辦法知道我們的異步函數啥時候結束。

  那我來問你, 如果你去車站接人,

  可是你又不知道對方何時下車,你會咋辦?

  把我電話號碼給他,快到了打我電話唄

  沒錯,Promise解決問題也采用了同樣的思路。

  它傳進來的resolve函數, 就好像一個對講機,

  當我們的異步任務要結束時,通過對講機 來通知Promise對象。

  也就是調用resolve方法

  new Promise(function(resolve){

  ajax("/pay/post",function(data){

  //當請求結束時,通過調用resolve方法,通知Promise對象,該任務已完成

  resolve(); //收到通知后,Promise會立刻開始函數2的執行

  })

  }).then(函數2);

  懂了,所以這個resolve函數,必須在異步任務的最后調用(例如ajax的回調方法),相當于告訴Promise對象,該任務結束,請開始下一個。

  完全正確

  問題5, 所以Promise也不過如此嘛,它沒有帶來什么功能上的革命性變化, 因為使用傳統的回調嵌套的方式,同樣可以完成效果。 說白了它就是編碼方式上的改進??

  基本是這樣的,但Promise帶來的編碼方式以及異步編程思路上的進步是非常巨大的。

  問題6, 那如果我有ajaxA、ajaxB、ajaxC三個異步任務,想按照先A后B再C的順序執行,像這樣寫行嗎?

  new Promise(function(resolve){

  ajax("/AAA", function(){

  resolve(); //通知Promise該任務結束

  })

  }).then(function(resolve){

  ajax("/BBB", function(){

  resolve();//通知Promise該任務結束

  })

  }).then(function(){

  ajax("/CCC", function(){ //.... })

  })

  上面的這種寫法是不對的。

  Promise的中文含義是“承諾”,

  則意味著,每一個Pormise對象,代表一次承諾

  而每一次承諾,只能保證一個任務的順序,也就是說

  new Promise(A).then(B); 這句話表示, 只能保證A和B的順序

  一旦A執行完,B開始后,這次承諾也就兌現了,Promise對象也就失效了

  那如果還有C呢? 我們就必須在函數B中,

  重新創建新的Promise對象,來完成下一個承諾,具體的寫法就像這樣:

  new Promise(函數1(resolve){

  ajaxA("xxxx", function(){

  resolve();//通知Promise該任務結束

  })

  }).then(函數2(){

  //在函數2開始運行后,第一次創建的Promise對象完成使命,已經不能再繼續工作。

  //此時,我們創建并返回了新的Promise對象

  return new Promise(function(resolve){

  ajaxB("xxxx", function(){

  resolve();//通知新的Promise對象該任務結束

  })

  })

  }).then(函數3(){ //盡管這里使用了鏈式調用,但負責執行函數3的,已經是新的Promise對象了

  // 如果,我們還有ajaxD需要順序調用

  // 那就必須在這里重新new Promise()對象了

  ajaxC("xxx", function(){ })

  })

  問題7, 懂了,那Promise還有什么其它強大的功能嗎?

  有啊,例如: 如果我有 A,B,C 三個異步任務,ABC同時開始執行

  當A,B,C三個任務全部都結束時,執任務D,

  傳統方法實現起來就比較復雜,Promise就非常簡單,就像這樣:

  Promise.all([new Promise(A), new Promise(B), new Promise(C)])

  .then(function(){

  D();

  });

  問題8, 那如果我希望A,B,C 其中任意一個任務完成,

  就馬上開始任務D,該怎么做?

  Promise.race([new Promise(A), new Promise(B), new Promise(C)])

  .then(function(){

  D();

  });

  恭喜你,在這么短的時間內學會了Promise

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
欧美18性精品| 日韩一级黄色大片| 精品视频免费观看| 亚洲第一页乱| 精品视频免费观看| 成人影院久久久久久影院| 99色视频在线| 一 级 黄 中国色 片| 99色播| 欧美爱色| 一本伊大人香蕉高清在线观看| 久久99中文字幕| 欧美激情一区二区三区在线播放| 国产视频一区在线| 国产福利免费观看| 午夜家庭影院| 日韩在线观看免费完整版视频| 美国一区二区三区| 国产成人精品影视| 亚洲精品久久久中文字| 精品久久久久久综合网| 日本在线www| 亚洲精品影院| 日韩一级黄色片| 亚欧视频在线| 欧美a级片免费看| 国产亚洲免费观看| 二级特黄绝大片免费视频大片| 久久精品成人一区二区三区| 99久久视频| 国产高清在线精品一区二区| 免费国产在线观看不卡| 日韩在线观看免费完整版视频| 成人免费一级纶理片| 天天做人人爱夜夜爽2020| 国产91丝袜高跟系列| 日韩av成人| 久久福利影视| 亚洲 欧美 成人日韩| 一级毛片视频在线观看| 二级特黄绝大片免费视频大片| 亚洲精品影院| 亚洲女人国产香蕉久久精品| 香蕉视频久久| 亚飞与亚基在线观看| 久久99这里只有精品国产| 四虎影视库| 欧美激情一区二区三区在线播放| 国产韩国精品一区二区三区| 欧美电影免费看大全| 午夜激情视频在线观看| 国产a免费观看| 999精品视频在线| 精品国产香蕉在线播出| 青青久久精品国产免费看| 国产成人啪精品| 国产伦久视频免费观看 视频| 青草国产在线观看| 国产国语在线播放视频| 国产亚洲免费观看| 九九精品久久久久久久久| 韩国三级视频网站| 美女免费毛片| 久久久久久久免费视频| 日韩在线观看免费完整版视频| 日韩在线观看视频网站| 日韩av片免费播放| 欧美1区2区3区| 欧美a级片视频| 亚飞与亚基在线观看| 精品久久久久久综合网| 久久国产精品永久免费网站| 亚洲第一页乱| 国产a视频| 亚洲精品影院| 国产成人精品综合在线| 国产视频一区二区在线观看| 亚久久伊人精品青青草原2020| 精品国产一区二区三区国产馆| 亚洲第一页色| 九九精品影院| 精品在线免费播放| 精品久久久久久中文字幕一区| 国产麻豆精品免费视频| 国产麻豆精品高清在线播放| 精品国产一区二区三区久久久狼| 国产精品自拍一区| 99色视频| 精品国产亚洲一区二区三区| 久久久久久久久综合影视网| 日本在线不卡视频| 中文字幕97| 精品视频在线看 | 亚洲不卡一区二区三区在线| 国产麻豆精品hdvideoss| 高清一级毛片一本到免费观看| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 亚洲天堂免费| 午夜欧美成人香蕉剧场| 国产国语对白一级毛片| 欧美国产日韩在线| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产韩国精品一区二区三区| 91麻豆tv| 国产伦久视频免费观看 视频| 午夜在线影院| 国产伦精品一区二区三区无广告 | 麻豆午夜视频| 999精品视频在线| 欧美a级v片不卡在线观看| 99热精品在线| 九九免费精品视频| 香蕉视频亚洲一级| 国产高清在线精品一区a| 成人a大片在线观看| 国产网站免费| 天天色成人网| 欧美国产日韩精品| 国产不卡精品一区二区三区| 黄视频网站免费观看| 麻豆午夜视频| 国产美女在线观看| 韩国毛片基地| 欧美激情在线精品video| 欧美大片一区| 国产成人啪精品视频免费软件| 精品视频在线看 | 成人影院久久久久久影院| 99久久精品国产片| 国产国产人免费视频成69堂| 亚洲精品影院久久久久久| 黄视频网站在线看| 欧美日本免费| 亚洲精品久久久中文字| 精品国产三级a| 午夜激情视频在线观看| 99色视频| 亚洲精品久久玖玖玖玖| 999久久66久6只有精品| 欧美激情一区二区三区视频 | 国产麻豆精品高清在线播放| 91麻豆精品国产片在线观看| 欧美爱爱动态| 亚飞与亚基在线观看| 国产高清在线精品一区二区| 欧美另类videosbestsex| a级黄色毛片免费播放视频| 欧美日本免费| 青青久久精品| 日韩中文字幕在线亚洲一区| 国产韩国精品一区二区三区| 精品国产香蕉伊思人在线又爽又黄| 亚洲第一页色| 精品视频在线看 | 精品久久久久久中文字幕一区| 久久精品欧美一区二区| a级毛片免费观看网站| 日韩男人天堂| 欧美a级片视频| 精品视频免费看| 国产精品12| 国产极品白嫩美女在线观看看| 久久国产精品自由自在| 黄视频网站在线观看| 色综合久久久久综合体桃花网| 成人免费一级纶理片| 久久99青青久久99久久| 免费一级片网站| 999精品在线| 国产91精品一区| 亚洲精品永久一区| 久久国产一区二区| 免费一级生活片| 成人免费一级纶理片| 99色视频在线| 国产伦理精品| 你懂的国产精品| 精品在线观看一区| 欧美国产日韩久久久| 精品视频在线观看一区二区三区| 日韩av成人| 日本免费乱理伦片在线观看2018| 在线观看导航| 一级女性全黄生活片免费| 日日爽天天| 精品在线观看一区| 久久精品免视看国产明星 | 亚洲 国产精品 日韩| 成人在激情在线视频| 成人a大片在线观看| 色综合久久天天综线观看| 国产成人精品综合| 精品国产亚洲一区二区三区| 免费一级片网站| 国产伦精品一区二区三区在线观看 | 欧美另类videosbestsex高清| 一级片片| 成人高清视频在线观看| 亚州视频一区二区| 日韩在线观看免费完整版视频|