成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

總結異步編程的六種方式

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

 [[265412]]

異步編程

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

  •  回調函數
  •  事件監聽
  •  發布訂閱模式
  •  Promise
  •  Generator (ES6)
  •  async (ES7)

異步編程傳統的解決方案:回調函數和事件監聽

初始示例:假設有兩個函數, f1 和 f2,f1 是一個需要一定時間的函數。 

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

回調函數

因為 f1 是一個需要一定時間的函數,所以可以將 f2 寫成 f1 的回調函數,將同步操作變成異步操作,f1 不會阻塞程序的運行,f2 也無需空空等待,例如 JQuery 的 ajax。

回調函數的demo: 

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

效果如下:

總結:回調函數易于實現、便于理解,但是多次回調會導致代碼高度耦合

事件監聽

腳本的執行不取決代碼的順序,而取決于某一個事件是否發生。

事件監聽的demo 

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

發布訂閱模式

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

發布訂閱模式的 demo 

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

Promise

Promise 實際就是一個對象, 從它可以獲得異步操作的消息,Promise 對象有三種狀態,pending(進行中)、fulfilled(已成功)和rejected(已失?。?。Promise 的狀態一旦改變之后,就不會在發生任何變化,將回調函數變成了鏈式調用。

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 函數是一個狀態機,封裝了多個內部狀態。執行 Generator 函數會返回一個遍歷器對象,使用該對象的 next() 方法,可以遍歷 Generator 函數內部的每一個狀態,直到 return 語句。

形式上,Generator 函數是一個普通函數,但是有兩個特征。一是,function關鍵字與函數名之間有一個星號;二是,函數體內部使用yield表達式, yield是暫停執行的標記。

next() 方法遇到yield表達式,就暫停執行后面的操作,并將緊跟在yield后面的那個表達式的值,作為返回的對象的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函數返回的是一個 Promise 對象,可以使用 then 方法添加回調函數,async 函數內部 return 語句返回的值,會成為 then 方法回調函數的參數。當函數執行的時候,一旦遇到await就會先返回,等到異步操作完成,再接著執行函數體內后面的語句。

1.await命令后面返回的是 Promise 對象,運行結果可能是rejected,所以***把await命令放在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. }) 
責任編輯:龐桂玉 來源: segmentfault
相關推薦

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網絡演進

2020-07-31 11:12:39

安全威脅網絡攻擊網絡安全

2022-01-14 10:34:50

黑客隱藏蹤跡網絡安全

2020-04-27 09:00:00

雙因素認證身份認證生物識別

2022-03-23 12:55:50

農業物聯網

2017-10-20 11:07:45

編程代碼編程模式

2023-05-10 13:58:13

服務限流系統

2021-01-08 10:52:22

物聯網萬物互聯IoT,Interne

2022-03-28 20:57:31

私有屬性class屬性和方法

2018-10-19 10:30:51

SD-WAN軟件定義廣域網網絡

2024-12-18 16:19:51

2023-10-30 11:53:37

繼承JS父類

2023-08-11 13:39:06

首席信息官IT領導

2022-07-15 10:30:41

ITCIO

2010-09-13 18:02:46

2018-08-03 16:40:06

前端前端框架微服務
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 色久伊人 | 欧美色欧美亚洲另类七区 | 天堂av中文在线 | 伊人网91 | 亚洲精品久久嫩草网站秘色 | 超碰综合 | 一区二区三区视频在线 | 亚洲欧美在线免费观看 | 国产精品久久久久久吹潮日韩动画 | 国产乱码精品一区二区三区中文 | 国产精品爱久久久久久久 | 欧美一区二区三区精品免费 | av一区二区三区四区 | 欧美一区二区三区在线免费观看 | 国产精品国产精品 | 亚洲精品久久久久中文字幕欢迎你 | 久久久久久久av | 国产欧美在线一区 | 欧美成人hd| 欧美成人免费 | 亚洲免费人成在线视频观看 | 日本字幕在线观看 | 亚洲一区二区精品视频在线观看 | 精品亚洲第一 | 国产精品久久久久av | 99精品在线 | 激情网站在线 | 午夜国产| 中文字幕视频在线 | 中文字幕av亚洲精品一部二部 | 特黄特色大片免费视频观看 | 亚洲一区二区三区四区视频 | 国产精品一区二区在线播放 | 91久久久久久久久久久 | 欧美最猛性xxxxx亚洲精品 | 国产精品v | 国产精品网址 | 黄色av网站在线免费观看 | 成人深夜福利 | 国产成人精品一区二区三 | 欧美亚洲一级 |