JavaScript中怎么處理并行請(qǐng)求

JavaScript中怎么處理并行請(qǐng)求,很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。

創(chuàng)新互聯(lián)公司成立于2013年,公司以成都網(wǎng)站制作、網(wǎng)站建設(shè)、系統(tǒng)開發(fā)、網(wǎng)絡(luò)推廣、文化傳媒、企業(yè)宣傳、平面廣告設(shè)計(jì)等為主要業(yè)務(wù),適用行業(yè)近百種。服務(wù)企業(yè)客戶1000+,涉及國(guó)內(nèi)多個(gè)省份客戶。擁有多年網(wǎng)站建設(shè)開發(fā)經(jīng)驗(yàn)。為企業(yè)提供專業(yè)的網(wǎng)站建設(shè)、創(chuàng)意設(shè)計(jì)、宣傳推廣等服務(wù)。 通過(guò)專業(yè)的設(shè)計(jì)、獨(dú)特的風(fēng)格,為不同客戶提供各種風(fēng)格的特色服務(wù)。

1、使用Promise.all

const startTime = new Date().getTime()
function request(time) {
  return new Promise(resolve => {
    setTimeout(() => {
      resolve(time)
    }, time)
  })
}
let request1 = request(3000)
let request2 = request(2000)
Promise.all([request1, request2]).then(res => {
  console.log(res, new Date() - startTime)  // [ 3000, 2000 ] 3001
})

2、自定義狀態(tài),在回調(diào)中判斷返回狀態(tài),待2個(gè)請(qǐng)求都有返回值時(shí)再做處理。

const startTime = new Date().getTime()
function request(time) {
  return new Promise(resolve => {
    setTimeout(() => {
      resolve(time)
    }, time)
  })
}
let state = [undefined, undefined]
let request1 = request(3000)
let request2 = request(2000)
request1.then(res => {
  state[0] = res
  process()
})
request2.then(res => {
  state[1] = res
  process()
})
function process() {
  if (state[0] && state[1]) {
    console.log(state, new Date() - startTime) // [ 3000, 2000 ] 3001
  }
}

3、generator,yield

const startTime = new Date().getTime()
function ajax(time, cb) {
  setTimeout(() => cb(time), time)
}
function request(time) {
  ajax(time, data => {
    it.next(data);
  })
}
function* main() {
  let request1 = request(3000);
  let request2 = request(2000);
  let res1 = yield request1
  let res2 = yield request2
  console.log(res1, res2, new Date() - startTime) // 2000 3000 3001
}
let it = main();
it.next();

4、有了generator,很容易想到async/await,畢竟async/await就是由generator實(shí)現(xiàn)的。

// setTimeout模擬異步請(qǐng)求,time為請(qǐng)求耗時(shí)
const startTime = new Date().getTime()
function request (time) {
  return new Promise(resolve => {
    setTimeout(() => {
      resolve(time)
    }, time)
  })
}
(async function () {
  let request1 = request(3000)
  let request2 = request(2000)
  let res1 = await request1
  console.log(res1, new Date() - startTime) // 3000 3001
  let res2 = await request2
  console.log(res2, new Date() - startTime) // 2000 3005
})()

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。

新聞標(biāo)題:JavaScript中怎么處理并行請(qǐng)求
文章分享:http://m.kartarina.com/article30/pphoso.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗(yàn)網(wǎng)站營(yíng)銷關(guān)鍵詞優(yōu)化網(wǎng)站排名云服務(wù)器企業(yè)網(wǎng)站制作

廣告

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

綿陽(yáng)服務(wù)器托管
主站蜘蛛池模板: 日日摸夜夜爽无码毛片精选| 西西444www无码大胆| 乱人伦人妻中文字幕无码| 精品无码久久久久久久久水蜜桃| 中文字幕无码av激情不卡久久| 无码人妻一区二区三区在线| 亚洲?V无码乱码国产精品| 免费A级毛片无码视频| 成年无码av片在线| 亚洲性无码AV中文字幕| 久久午夜无码鲁丝片午夜精品| 亚洲久热无码av中文字幕| 亚洲ⅴ国产v天堂a无码二区| 午夜无码一区二区三区在线观看| 精品无码久久久久久午夜| 成人无码区免费A∨直播| 人妻aⅴ中文字幕无码| 无码国产精品一区二区免费式影视 | yy111111电影院少妇影院无码| 亚洲AV无码成人精品区狼人影院| 无码伊人66久久大杳蕉网站谷歌 | 亚洲av无码国产精品色午夜字幕| 久久人妻无码中文字幕| 亚洲AV无码一区二区三区国产| 久久无码AV一区二区三区| 亚洲av永久无码精品古装片 | 少妇性饥渴无码A区免费| 无码日韩人妻精品久久| 国产精品午夜无码AV天美传媒| 亚洲精品无码专区| 亚洲中文无码永久免费| 亚洲人av高清无码| 亚洲a∨无码一区二区| 久久人妻无码一区二区| 亚洲av永久无码天堂网| 亚洲精品久久久久无码AV片软件| 亚洲AV成人无码天堂| 亚洲人av高清无码| 精品无码一区二区三区水蜜桃| 日韩乱码人妻无码中文字幕视频| 一本大道无码日韩精品影视|