欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2019年05月17日 09:33:00   作者:Aima  
這篇文章主要介紹了javascript異步編程的六種方式總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

異步編程

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

  1. 回調(diào)函數(shù)
  2. 事件監(jiān)聽
  3. 發(fā)布訂閱模式
  4. Promise
  5. Generator (ES6)
  6. async (ES7)

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

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

function f1() {
  setTimeout(function(){
    console.log('先執(zhí)行 f1')
  },1000)
}
function f2() {
  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:

function f1(f2){
  setTimeout(function(){
    console.log('先執(zhí)行 f1')
  },1000)
  f2()
}
function f2() {
  console.log('再執(zhí)行 f2')
}

效果如下:

 

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

事件監(jiān)聽

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

事件監(jiān)聽的demo

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

發(fā)布訂閱模式

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

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

//訂閱done事件
$('#app').on('done',function(data){
  console.log(data)
})
//發(fā)布事件
$('#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

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 函數(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

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函數(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

async function demo() {
 try {
  await new Promise(function (resolve, reject) {
   // something
  });
 } catch (err) {
  console.log(err);
 }
}

demo().then(data => {
  console.log(data) // 
})

參考文獻(xiàn)

https://developers.google.com/web/fundamentals/primers/promises
http://es6.ruanyifeng.com

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 微信小程序?qū)崿F(xiàn)自定義picker選擇器彈窗內(nèi)容

    微信小程序?qū)崿F(xiàn)自定義picker選擇器彈窗內(nèi)容

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)自定義picker選擇器彈窗內(nèi)容,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • js函數(shù)返回多個(gè)返回值的示例代碼

    js函數(shù)返回多個(gè)返回值的示例代碼

    js函數(shù)一般都是返回一個(gè)值,在本例教程中將為大家介紹下如何返回多個(gè)返回值,喜歡的朋友可以了解下
    2013-11-11
  • js獲取隱藏元素的寬高

    js獲取隱藏元素的寬高

    本文主要介紹了使用js獲取隱藏元素寬高的解決方案以及代碼思路,具有很好的參考價(jià)值,下面跟著小編一起來看下吧
    2017-02-02
  • 詳解js獲取video任意時(shí)間的畫面截圖

    詳解js獲取video任意時(shí)間的畫面截圖

    這篇文章主要介紹了js獲取video任意時(shí)間的畫面截圖,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 微信小程序?qū)崿F(xiàn)左滑動(dòng)刪除效果

    微信小程序?qū)崿F(xiàn)左滑動(dòng)刪除效果

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)左滑動(dòng)刪除效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • 使用Visual?Studio?2022開發(fā)前端的詳細(xì)教程

    使用Visual?Studio?2022開發(fā)前端的詳細(xì)教程

    這篇文章主要介紹了使用Visual?Studio?2022開發(fā)前端,在瀏覽器中可以使用CDN源引用需要的客戶端庫,可如果在企業(yè)內(nèi)網(wǎng)使用,無法訪問CDN源時(shí),需要將客戶端庫下載到本地使用,需要的朋友可以參考下
    2022-05-05
  • uniapp小程序?qū)崿F(xiàn)瀑布流布局的思路與代碼

    uniapp小程序?qū)崿F(xiàn)瀑布流布局的思路與代碼

    這篇文章主要給大家介紹了關(guān)于uniapp小程序?qū)崿F(xiàn)瀑布流布局的思路與代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 老生常談JavaScript設(shè)計(jì)模式之call,apply,this詳解

    老生常談JavaScript設(shè)計(jì)模式之call,apply,this詳解

    這篇文章主要介紹了JavaScript設(shè)計(jì)模式之call,apply,this的相關(guān)知識,本文通過示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2025-06-06
  • JavaScript學(xué)習(xí)筆記之創(chuàng)建對象

    JavaScript學(xué)習(xí)筆記之創(chuàng)建對象

    在JavaScript中對象是一種基本的數(shù)據(jù)類型,在數(shù)據(jù)結(jié)構(gòu)上是一種散列表,可以看作是屬性的無序集合,除了原始值其他一切都是對象。這篇文章主要給大家介紹JavaScript學(xué)習(xí)筆記之創(chuàng)建對象,需要的朋友參考下吧
    2016-03-03
  • JavaScript復(fù)制文案到剪貼板小技巧

    JavaScript復(fù)制文案到剪貼板小技巧

    這篇文章主要為大家介紹了JavaScript復(fù)制文案到剪貼板實(shí)現(xiàn)小技巧,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07

最新評論