欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

javascript異步編程有哪些方式

這篇文章主要為大家展示了“javascript異步編程有哪些方式”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“javascript異步編程有哪些方式”這篇文章吧。

創(chuàng)新互聯(lián)是一家專業(yè)提供新邵企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計制作、做網(wǎng)站、H5網(wǎng)站設(shè)計、小程序制作等業(yè)務(wù)。10年已為新邵眾多企業(yè)、政府機構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站建設(shè)公司優(yōu)惠進(jìn)行中。

異步編程

眾所周知 JavaScript 是單線程工作,也就是只有一個腳本執(zhí)行完成后才能執(zhí)行下一個腳本,兩個腳本不能同時執(zhí)行,如果某個腳本耗時很長,后面的腳本都必須排隊等著,會拖延整個程序的執(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è)有兩個函數(shù), f1 和 f2,f1 是一個需要一定時間的函數(shù)。

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

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

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

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

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

效果如下:

 javascript異步編程有哪些方式

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

事件監(jiān)聽

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

事件監(jiān)聽的demo

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

發(fā)布訂閱模式

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

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

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

Promise

Promise 實際就是一個對象, 從它可以獲得異步操作的消息,Promise 對象有三種狀態(tài),pending(進(jìn)行中)、fulfilled(已成功)和rejected(已失?。?。Promise 的狀態(tài)一旦改變之后,就不會在發(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ù)是一個狀態(tài)機,封裝了多個內(nèi)部狀態(tài)。執(zhí)行 Generator 函數(shù)會返回一個遍歷器對象,使用該對象的 next() 方法,可以遍歷 Generator 函數(shù)內(nèi)部的每一個狀態(tài),直到 return 語句。

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

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

1.await命令后面返回的是 Promise 對象,運行結(jié)果可能是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) // 
})

以上是“javascript異步編程有哪些方式”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

名稱欄目:javascript異步編程有哪些方式
分享網(wǎng)址:http://aaarwkj.com/article26/jesicg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動網(wǎng)站建設(shè)、全網(wǎng)營銷推廣、網(wǎng)站建設(shè)、微信公眾號、網(wǎng)站維護(hù)網(wǎng)站排名

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運營
蜜臀av一区二区三区人妻| 国产熟女精品自拍嫩草| 久久精品国产亚洲av高清观看| 精品少妇一区二区三区| 日韩国产乱码一区中文字幕| 久久久这里只有精品99| 欧美日韩免费r在线视频| 白嫩少妇情久久密月久久| 日本不卡一二区不久精品免费| 欧美日韩国产成人一区| 欧美午夜福利在线视频| 欧美日韩国产一下老妇| 亚洲国产日韩欧美在线播放| 日本理论午夜三级在线观看| 免费在线观看成人av| 日本成人午夜在线观看| 日本午夜福利视频在线观看| 国产高潮精品呻吟久久av| 亚洲国产日韩伦中文字幕| 亚洲一区二区日韩人妻| 欧美口爆吞精在线观看| 成人免费在线观看午夜| 三级日本一区二区三区| 国产网红女主播视频一区二区| av在线播放网址网站| 99久久夜国产精品| 欧美欧美欧美欧美一二三区| 国产精品黄色片在线观看 | 亚洲黄色片一区二区三区| 超碰在线免费视频97| 精品国产美女主播在线| 亚洲欧美国产成人在线| 国产女主播在线观看免费观看| 国产一区二区传媒视频| 日本加勒比系列在线播放| 人妻少妇被粗大爽av| 日韩精品二区在线观看| 亚洲一区二区三区日韩欧美| 日韩人妻熟妇中文字幕| 亚洲av污精品一区二区三区| 日产一区二区三区网站|