總結非同步程式設計的六種方式
非同步程式設計
眾所周知 JavaScript 是
單執行緒
工作,也就是隻有一個指令碼執行完成後才能執行下一個指令碼,兩個指令碼不能同時執行,如果某個指令碼耗時很長,後面的指令碼都必須排隊等著,會拖延整個程式的執行。以下為幾種非同步程式設計方式的總結,希望與君共勉。
- 回撥函式
- 事件監聽
- 釋出訂閱模式
- Promise
- Generator (ES6)
- async (ES7)
非同步程式設計傳統的解決方案: 回撥函式和 事件監聽
初始示例:假設有兩個函式, f1 和 f2,f1 是一個需要一定時間的函式。
function f1() { setTimeout(function(){ console.log('先執行 f1') },1000) }function f2() { console.log('再執行 f2') }
回撥函式
因為 f1 是一個需要一定時間的函式,所以可以將 f2 寫成 f1 的
回撥函式
,將同步操作變成非同步操作,f1 不會阻塞程式的執行,f2 也無需空空等待,例如 JQuery 的 ajax。
回撥函式的demo:
function f1(f2){ setTimeout(function(){ console.log('先執行 f1') },1000) f2() }function f2() { console.log('再執行 f2') }
效果如下:
總結:回撥函式易於實現、便於理解,但是多次回撥會導致程式碼高度耦合
事件監聽
指令碼的執行不取決程式碼的順序,而取決於某一個事件是否發生。
事件監聽的demo
$(document).ready(function(){ console.log('DOM 已經 ready') });
釋出訂閱模式
釋出/訂閱模式是利用一個訊息中心,釋出者釋出一個訊息給訊息中心,訂閱者從訊息中心訂閱該訊息,。類似於 vue 的父子元件之間的傳值。
釋出訂閱模式的 demo
//訂閱done事件$('#app').on('done',function(data){ console.log(data) })//釋出事件$('#app').trigger('done,'haha')
Promise
Promise 實際就是一個物件, 從它可以獲得非同步操作的訊息,Promise 物件有三種狀態,pending(進行中)、fulfilled(已成功)和rejected(已失敗)。Promise 的狀態一旦改變之後,就不會在發生任何變化,將回撥函式變成了鏈式呼叫。
Promise 封裝非同步請求demo
export default function getMethods (url){ return new Promise(function(resolve, reject){ axios.get(url).then(res => { resolve(res) }).catch(err =>{ reject(err) }) }) } getMethods('/api/xxx').then(res => { console.log(res) }, err => { console.log(err) })
Generator
Generator 函式是一個狀態機,封裝了多個內部狀態。執行 Generator 函式會返回一個遍歷器物件,使用該物件的 next() 方法,可以遍歷 Generator 函式內部的每一個狀態,直到 return 語句。
形式上,Generator 函式是一個普通函式,但是有兩個特徵。一是,function關鍵字與函式名之間有一個星號;二是,函式體內部使用yield表示式, yield是暫停執行的標記。
next() 方法遇到yield表示式,就暫停執行後面的操作,並將緊跟在yield後面的那個表示式的值,作為返回的物件的value屬性值。
Generator 的 demo
function *generatorDemo() { yield 'hello'; yield 1 + 2; return 'ok'; } var demo = generatorDemo() demo.next() // { value: 'hello', done: false } demo.next() // { value: 3, done: false } demo.next() // { value: 'ok', done: ture } demo.next() // { value: undefined, done: ture }
async
async函式返回的是一個 Promise 物件,可以使用 then 方法新增回撥函式,async 函式內部 return 語句返回的值,會成為 then 方法回撥函式的引數。當函式執行的時候,一旦遇到await就會先返回,等到非同步操作完成,再接著執行函式體內後面的語句。
1.await命令後面返回的是 Promise 物件,執行結果可能是rejected,所以最好把await命令放在try...catch程式碼塊中。
async 的 demo1
async function demo() { try { await new Promise(function (resolve, reject) { // something }); } catch (err) { console.log(err); } } demo().then(data => { console.log(data) // })
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69946034/viewspace-2658010/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- JS 非同步程式設計六種方案JS非同步程式設計
- javascript 非同步程式設計的5種方式JavaScript非同步程式設計
- Javascript非同步程式設計總結JavaScript非同步程式設計
- Flutter 中的非同步程式設計總結Flutter非同步程式設計
- JS非同步程式設計的幾種方式及區別JS非同步程式設計
- 非程式設計天才參與開源專案的14種方式程式設計
- 好程式設計師分享JavaScript六種繼承方式詳解程式設計師JavaScript繼承
- 【程式設計】java jdbc/ojdbc 連結oracle的三種方式程式設計JavaJDBCOracle
- Socket程式設計中的同步、非同步、阻塞和非阻塞(轉)程式設計非同步
- python 網路程式設計----非阻塞或非同步程式設計Python程式設計非同步
- [譯] 非同步程式設計:阻塞與非阻塞非同步程式設計
- Golang非同步程式設計方式和技巧Golang非同步程式設計
- JavaScript非同步程式設計的6種方法JavaScript非同步程式設計
- Javascript非同步程式設計的4種方法JavaScript非同步程式設計
- Promise-在Java中以同步的方式非同步程式設計PromiseJava非同步程式設計
- 非同步程式設計小結非同步程式設計
- 設計模式大總結(六):命令模式設計模式
- 網路IO之阻塞、非阻塞、同步、非同步總結非同步
- 程式設計師獲取程式設計靈感的 10 種方式程式設計師
- 結對程式設計總結程式設計
- 非同步程式設計新方式async/await非同步程式設計AI
- JS非同步程式設計之Promise詳解和使用總結JS非同步程式設計Promise
- iOS多執行緒程式設計:執行緒同步總結iOS執行緒程式設計
- 自己總結物件導向程式設計的總結物件程式設計
- 程式設計技巧總結程式設計
- 程式設計師浪費生命的幾種方式程式設計師
- 程式設計師初學機器學習的四種方式程式設計師機器學習
- Entity Farmework領域建模方式 3種程式設計方式程式設計
- 阻塞/非阻塞讀寫總結、tcp網路程式設計的本質、muduo::Buffer設計簡介TCP程式設計
- 【程式設計素質】程式設計思想總結程式設計
- Python種匯入模組的三種方式總結Python
- 【譯】JavaScript的工作原理:事件迴圈及非同步程式設計的出現和 5 種更好的 async/await 程式設計方式JavaScript事件非同步程式設計AI
- 程式設計師的“非程式設計師”之路程式設計師
- React | ref三種使用方式總結React
- Python 程式設計中常用的 12 種基礎知識總結Python程式設計
- Python 程式設計中常用的12種基礎知識總結Python程式設計
- Python程式設計中常用的12種基礎知識總結Python程式設計
- Nio程式設計模型總結程式設計模型