国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

總結(jié)異步編程的六種方式

開發(fā) 前端
眾所周知 JavaScript 是單線程工作,也就是只有一個(gè)腳本執(zhí)行完成后才能執(zhí)行下一個(gè)腳本,那么如何讓程序像人類一樣可以多線程工作呢?以下為幾種異步編程方式的總結(jié),希望與君共勉。

 [[265412]]

異步編程

眾所周知 JavaScript 是單線程工作,也就是只有一個(gè)腳本執(zhí)行完成后才能執(zhí)行下一個(gè)腳本,兩個(gè)腳本不能同時(shí)執(zhí)行,如果某個(gè)腳本耗時(shí)很長,后面的腳本都必須排隊(duì)等著,會(huì)拖延整個(gè)程序的執(zhí)行。那么如何讓程序像人類一樣可以多線程工作呢?以下為幾種異步編程方式的總結(jié),希望與君共勉。

  •  回調(diào)函數(shù)
  •  事件監(jiān)聽
  •  發(fā)布訂閱模式
  •  Promise
  •  Generator (ES6)
  •  async (ES7)

異步編程傳統(tǒng)的解決方案:回調(diào)函數(shù)和事件監(jiān)聽

初始示例:假設(shè)有兩個(gè)函數(shù), f1 和 f2,f1 是一個(gè)需要一定時(shí)間的函數(shù)。 

  1. function f1() {  
  2.     setTimeout(function(){  
  3.         console.log('先執(zhí)行 f1')  
  4.     },1000)  
  5.  
  6. function f2() {  
  7.     console.log('再執(zhí)行 f2')  

回調(diào)函數(shù)

因?yàn)?f1 是一個(gè)需要一定時(shí)間的函數(shù),所以可以將 f2 寫成 f1 的回調(diào)函數(shù),將同步操作變成異步操作,f1 不會(huì)阻塞程序的運(yùn)行,f2 也無需空空等待,例如 JQuery 的 ajax。

回調(diào)函數(shù)的demo: 

  1. function f1(f2){  
  2.     setTimeout(function(){  
  3.         console.log('先執(zhí)行 f1')  
  4.     },1000)  
  5.     f2()  
  6.  
  7. function f2() {  
  8.     console.log('再執(zhí)行 f2')  

效果如下:

總結(jié):回調(diào)函數(shù)易于實(shí)現(xiàn)、便于理解,但是多次回調(diào)會(huì)導(dǎo)致代碼高度耦合

事件監(jiān)聽

腳本的執(zhí)行不取決代碼的順序,而取決于某一個(gè)事件是否發(fā)生。

事件監(jiān)聽的demo 

  1. $(document).ready(function(){  
  2.      console.log('DOM 已經(jīng) ready')  
  3. }); 

發(fā)布訂閱模式

發(fā)布/訂閱模式是利用一個(gè)消息中心,發(fā)布者發(fā)布一個(gè)消息給消息中心,訂閱者從消息中心訂閱該消息,。類似于 vue 的父子組件之間的傳值。

發(fā)布訂閱模式的 demo 

  1. //訂閱done事件  
  2. $('#app').on('done',function(data){  
  3.     console.log(data)  
  4. })  
  5. //發(fā)布事件  
  6. $('#app').trigger('done,'haha') 

Promise

Promise 實(shí)際就是一個(gè)對象, 從它可以獲得異步操作的消息,Promise 對象有三種狀態(tài),pending(進(jìn)行中)、fulfilled(已成功)和rejected(已失敗)。Promise 的狀態(tài)一旦改變之后,就不會(huì)在發(fā)生任何變化,將回調(diào)函數(shù)變成了鏈?zhǔn)秸{(diào)用。

Promise 封裝異步請求demo 

  1. export default function getMethods (url){  
  2.     return new Promise(function(resolve, reject){  
  3.         axios.get(url).then(res => {  
  4.             resolve(res)  
  5.         }).catch(err => 
  6.             reject(err)  
  7.         })  
  8.     })  
  9.  
  10. getMethods('/api/xxx').then(res => {  
  11.     console.log(res)  
  12. }, err => {  
  13.     console.log(err)  
  14. }) 

Generator

Generator 函數(shù)是一個(gè)狀態(tài)機(jī),封裝了多個(gè)內(nèi)部狀態(tài)。執(zhí)行 Generator 函數(shù)會(huì)返回一個(gè)遍歷器對象,使用該對象的 next() 方法,可以遍歷 Generator 函數(shù)內(nèi)部的每一個(gè)狀態(tài),直到 return 語句。

形式上,Generator 函數(shù)是一個(gè)普通函數(shù),但是有兩個(gè)特征。一是,function關(guān)鍵字與函數(shù)名之間有一個(gè)星號;二是,函數(shù)體內(nèi)部使用yield表達(dá)式, yield是暫停執(zhí)行的標(biāo)記。

next() 方法遇到y(tǒng)ield表達(dá)式,就暫停執(zhí)行后面的操作,并將緊跟在yield后面的那個(gè)表達(dá)式的值,作為返回的對象的value屬性值。

Generator 的 demo 

  1. function *generatorDemo() {  
  2.   yield 'hello';  
  3.   yield  1 + 2;  
  4.   return 'ok';  
  5.  
  6. var demo = generatorDemo()  
  7. demo.next()   // { value: 'hello', done: false }   
  8. demo.next()   // { value: 3, done: false }   
  9. demo.next()   // { value: 'ok', done: ture }   
  10. demo.next()   // { value: undefined, done: ture }  

async

async函數(shù)返回的是一個(gè) Promise 對象,可以使用 then 方法添加回調(diào)函數(shù),async 函數(shù)內(nèi)部 return 語句返回的值,會(huì)成為 then 方法回調(diào)函數(shù)的參數(shù)。當(dāng)函數(shù)執(zhí)行的時(shí)候,一旦遇到await就會(huì)先返回,等到異步操作完成,再接著執(zhí)行函數(shù)體內(nèi)后面的語句。

1.await命令后面返回的是 Promise 對象,運(yùn)行結(jié)果可能是rejected,所以***把a(bǔ)wait命令放在try...catch代碼塊中。

async 的 demo1 

  1. async function demo() {  
  2.   try {  
  3.     await new Promise(function (resolve, reject) {  
  4.       // something  
  5.     });  
  6.   } catch (err) { 
  7.     console.log(err);  
  8.   }  
  9.  
  10. demo().then(data => {  
  11.     console.log(data)  //   
  12. }) 
責(zé)任編輯:龐桂玉 來源: segmentfault
相關(guān)推薦

2019-01-17 10:58:52

JS異步編程前端

2017-06-26 10:35:58

前端JavaScript繼承方式

2025-02-27 00:00:30

SpringJava方式

2022-05-12 09:02:50

編程語言PythonJava

2009-02-11 09:46:00

ASON網(wǎng)絡(luò)演進(jìn)

2020-04-27 09:00:00

雙因素認(rèn)證身份認(rèn)證生物識別

2020-07-31 11:12:39

安全威脅網(wǎng)絡(luò)攻擊網(wǎng)絡(luò)安全

2022-01-14 10:34:50

黑客隱藏蹤跡網(wǎng)絡(luò)安全

2022-03-23 12:55:50

農(nóng)業(yè)物聯(lián)網(wǎng)

2017-10-20 11:07:45

編程代碼編程模式

2023-05-10 13:58:13

服務(wù)限流系統(tǒng)

2021-01-08 10:52:22

物聯(lián)網(wǎng)萬物互聯(lián)IoT,Interne

2022-07-15 10:30:41

ITCIO

2023-08-11 13:39:06

首席信息官IT領(lǐng)導(dǎo)

2022-03-28 20:57:31

私有屬性class屬性和方法

2023-10-30 11:53:37

繼承JS父類

2024-12-18 16:19:51

2018-10-19 10:30:51

SD-WAN軟件定義廣域網(wǎng)網(wǎng)絡(luò)

2010-09-13 18:02:46

2025-01-21 10:04:40

Java并發(fā)阻塞隊(duì)列
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

在线观看中文| 亚洲美女久久| 欧美在线观看禁18| 中文在线观看视频| 亚洲欧美日韩小说| 超碰在线播放91| 2017欧美狠狠色| 欧美日韩一区二区在线免费观看| 国产精品中文字幕日韩精品| 国产在线拍揄自揄拍无码| 国产精品综合一区二区| 2022中文字幕| av电影一区二区| 激情综合网俺也去| 中文字幕一区在线观看视频| 男人在线视频资源| 亚洲影视在线观看| 免费成人av电影| 7777精品伊人久久久大香线蕉完整版 | 91在线播放国产| 亚洲欧美一区在线| 日本一区二区久久精品| 国产美女娇喘av呻吟久久| 亚洲中文字幕无码专区| 中文字幕乱码亚洲精品一区| 中文字幕理伦片免费看| 91成人在线精品| 51av在线| 欧美激情亚洲激情| 久久美女精品| 欧美久久久久久久| 成人av网在线| 中文字幕在线视频不卡| 538在线一区二区精品国产| 亚洲妇女成熟| 2019精品视频| 国产精品亚洲欧美| 亚洲中文字幕无码专区| 亚洲精品成a人| 婷婷在线视频| 一区二区亚洲精品国产| 麻豆一区二区| 免费h精品视频在线播放| 国产不卡视频一区二区三区| 色成人亚洲网| 欧美精品一二三区| 亚洲综合伊人| 91久久久一线二线三线品牌| 狠狠色丁香久久婷婷综合_中| 久久这里只精品| 欧美精品成人一区二区三区四区| 日本肉肉一区| 国产精品一区二区电影| 精品亚洲porn| 最新四虎影在线在永久观看www| 日韩一区二区三区av| 亚洲成人偷拍| 久久人人97超碰人人澡爱香蕉| 91偷拍与自偷拍精品| 麻豆影视在线| 主播福利视频一区| 国内揄拍国内精品久久| 男人操女人逼免费视频| 精品久久中文字幕久久av| 亚洲www免费| 欧美在线视频一区二区| 久久99久久精品欧美| 在线免费福利| xxxxx成人.com| 宅男噜噜噜66一区二区| 中文字幕桃花岛| 日韩激情av在线免费观看| 婷婷成人在线| 日韩不卡一二区| 在线视频一区二区三区| 哺乳挤奶一区二区三区免费看| 亚洲欧洲三级| 日本韩国欧美国产| 久久av国产紧身裤| 自拍视频在线播放| 在线观看免费网站黄| 亚洲欧洲激情在线| 国产在视频线精品视频www666| 欧美精品七区| 色噜噜一区二区| 精品一区二区久久| 在线影视一区| 欧美日韩爱爱视频| 美女精品在线观看| 3dmax动漫人物在线看| 在线观看国产精品日韩av| 亚洲午夜一区| 情se视频网在线观看| 久久成年人免费电影| 免费在线看成人av| av在线免费一区| 国产成人精品视频在线| 97久久精品人人爽人人爽蜜臀| 欧美videos极品另类| 国产精品永久在线| 国产精品乱码一区二区三区软件 | 国产精品免费观看| 91禁外国网站| 99r精品视频| 超碰超碰人人人人精品| 欧美一区二区三区成人久久片| 亚洲一区二区美女| 欧美激情网址| 日日噜噜夜夜狠狠| 欧美大片免费观看| 久久综合色天天久久综合图片| 暧暧视频在线免费观看| 鲁丝一区二区三区免费| 欧美日韩亚洲91| 日韩中文首页| 超碰在线图片| 国产精品久久久久不卡| 亚洲三级免费观看| 伊人春色之综合网| 小泽玛利亚视频在线观看| 欧美成年人视频| 成人污视频在线观看| www.26天天久久天堂| 激情六月天婷婷| 国产一区二区三区欧美| 国产成人免费视频网站高清观看视频 | 国产福利电影一区二区三区| 9765激情中文在线| 亚洲一区二区三区午夜| 日韩精品中文在线观看| 国产综合色精品一区二区三区| 高清电影在线免费观看| 日韩久久精品一区二区三区| 精品国产一区二区三区忘忧草 | 亚洲精品.com| 国产高清www| 欧美精品一区二区免费| 国产蜜臀av在线一区二区三区| 国产精品午夜av| 国产特级淫片免费看| 国产精品一香蕉国产线看观看| 五月激情六月综合| 亚洲乱码电影| 快射视频在线观看| 制服诱惑一区| zzjj国产精品一区二区| 亚洲欧美在线视频| 91成人网在线观看| 在线观看电影av| 成人免费观看在线| 69视频在线播放| 欧美日韩亚洲天堂| 日韩精品国产欧美| 欧美视频精品| h七七www色午夜日本| 久久蜜臀精品av| 777av视频| 欧美亚洲视频在线看网址| 欧美日韩亚洲精品一区二区三区| 国产日本精品| 日日av拍夜夜添久久免费| 国产成人a亚洲精v品无码| 国产精品免费看久久久香蕉| 欧美日韩一本到| 国产大陆a不卡| 欧美色图一区| 神马午夜伦理不卡| www.欧美日本| 国产精品视频在线免费观看| 亚洲欧美一区二区精品久久久| 久久久99精品免费观看| 中文在线播放一区二区| 中文不卡1区2区3区| av网站一区| 免费久久99精品国产自| 久久久999精品| 欧美调教femdomvk| 成人午夜免费视频| 五月激情综合| www.一区| 福利视频在线看| 国产精品视频一区二区三区四区五区 | 成人免费不卡视频| 欧美电影三区| 99久久精品一区二区成人| 91精品久久久久久9s密挑| 在线电影看在线一区二区三区| 91国产在线精品| 精品国产污网站| 午夜电影网亚洲视频| 国产九色精品成人porny| 国产精品99视频| 久久三级毛片| av免费在线观| 中国黄色在线视频| 人人妻人人添人人爽欧美一区| 国产精品久久亚洲7777| 97在线视频精品| 亚洲免费中文字幕| 欧美日韩国产综合久久|