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

淺談JS三座大山之異步和單線程

 更新時(shí)間:2021年06月04日 10:58:40   作者:熊貓程序員  
首先我們要知道,js這門語(yǔ)言是單線程的,同時(shí)只能做一件事,比如說(shuō)渲染dom,執(zhí)行js方法,這些事情只能一個(gè)一個(gè)做,不能分開(kāi)執(zhí)行。(因?yàn)閖s需要操作dom,當(dāng)兩個(gè)js方法同時(shí)操作一個(gè)dom的時(shí)候就會(huì)出問(wèn)題,所以js被設(shè)計(jì)成了單線程)。本文將介紹JS三座大山之異步和單線程。

單線程

但是我們?cè)陂_(kāi)發(fā)中,遇到請(qǐng)求網(wǎng)絡(luò),或者定時(shí)任務(wù)的時(shí)候,如果等待網(wǎng)絡(luò)請(qǐng)求結(jié)束或者定時(shí)任務(wù)結(jié)束的時(shí)候再去做其他事情,這樣頁(yè)面就會(huì)卡住,所以js有異步機(jī)制解決這個(gè)問(wèn)題。

異步

異步的特點(diǎn)是不會(huì)阻塞后面的代碼執(zhí)行,當(dāng)同步任務(wù)執(zhí)行完畢之后,再執(zhí)行異步任務(wù)。相對(duì)的,同步會(huì)阻止代碼執(zhí)行。異步任務(wù)的應(yīng)用主要有網(wǎng)絡(luò)請(qǐng)求和定時(shí)任務(wù)。

異步是通過(guò)callback的方式實(shí)現(xiàn)的,在callback里面執(zhí)行異步執(zhí)行的代碼,但是有一些場(chǎng)景比如我們有三個(gè)網(wǎng)絡(luò)請(qǐng)求abc需要依次執(zhí)行,在a的回調(diào)里發(fā)起b請(qǐng)求,在b的回調(diào)里發(fā)起c請(qǐng)求,這樣會(huì)造成一種很混亂的寫法,稱之為回調(diào)地獄,可以試想一下,如果頁(yè)面邏輯過(guò)于復(fù)雜,需要依次調(diào)用10個(gè)接口,那么代碼的可讀性會(huì)非常非常差,我們?nèi)绻吹搅藙e人的這種代碼難免內(nèi)心奔跑一萬(wàn)只神獸。

promise基本用法:

let fun1 = function(flag){
    return new Promise((resolve,reject)=>{
    if(flag){
        setTimeout(() => {
        resolve("success")
        }, 1000);
    }else{
        setTimeout(() => {
        reject("fail")
        }, 1000);
    }
    })
}
  
fun1(true).then((res)=>{
    console.log(res)//success
}).catch((res)=>{
    console.log(res)
})
fun1(false).then((res)=>{
    console.log(res)
}).catch((res)=>{
    console.log(res)//fail
})

上面是一個(gè)最簡(jiǎn)單的promise函數(shù),promise函數(shù)返回一個(gè)Promise對(duì)象,參數(shù)是一個(gè)函數(shù),接收兩個(gè)參數(shù)resolve和reject,這兩個(gè)參數(shù)也是函數(shù),當(dāng)執(zhí)行resolve()或者reject()的時(shí)候,函數(shù)返回.

如果執(zhí)行了resolve(),就會(huì)在調(diào)用的時(shí)候執(zhí)行then()方法,并接收resove()返回的參數(shù);

如果執(zhí)行了reject(),就會(huì)在調(diào)用的時(shí)候執(zhí)行catch()方法,并接收reject()返回的參數(shù);

用promise重新實(shí)現(xiàn)一下上面三個(gè)網(wǎng)絡(luò)請(qǐng)求的問(wèn)題:

let callService = function(url){
      return new Promise((resolve,reject)=>{
          axios.get(url).then((res)=>{
            resolve(res)
          }).catch((err)=>{
            reject(err)
          })
      
      })
    }
    const url1 = "/user/url1"
    const url2 = "/user/url2"
    const url3 = "/user/url3"
    callService(url1).then((res)=>{
      // do something
      return callService(url2)
    }).then(()=>{
      // do something
      return callService(url3)
    }).then((res)=>{
      // do something
    }).catch((err)=>{
      console.log(err)
    })

用上面的寫法重新實(shí)現(xiàn)之后,寫法上只會(huì)有一層,而不會(huì)陷入層層的回調(diào)之中。

promise.all

promise.all可以將多個(gè)promise包裝成一個(gè)新的實(shí)例,成功的時(shí)候返回一個(gè)數(shù)組,誰(shuí)先失敗返回誰(shuí)的值。

promise.all方法可以幫我們處理日常開(kāi)發(fā)中多接口同時(shí)調(diào)用的處理問(wèn)題。

let p1 = new Promise((resolve, reject) => {
  resolve('成功了')
})

let p2 = new Promise((resolve, reject) => {
  resolve('success')
})

Promise.all([p1, p2]).then((result) => {
  console.log(result)               //['成功了', 'success']
}).catch((error) => {
  console.log(error)
})

promise.race

這個(gè)方法的作用是多個(gè)接口賽跑,哪個(gè)跑得快就返回哪個(gè)

Promise.race([p1, p2]).then((result) => {
  console.log(result)
}).catch((error) => {
  console.log(error) 
})

以上就是淺談JS三座大山之異步和單線程的詳細(xì)內(nèi)容,更多關(guān)于JS三座大山之異步和單線程的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • JavaScript實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)

    JavaScript實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • javascript修改表格背景色實(shí)例代碼分享

    javascript修改表格背景色實(shí)例代碼分享

    這篇文章主要介紹了javascript修改表格背景色實(shí)例,代碼簡(jiǎn)單,大家參考使用吧
    2013-12-12
  • js?scrollTop如何到達(dá)指定位置

    js?scrollTop如何到達(dá)指定位置

    很早之前就想分享這篇心得,幸之今天能在這里完成,好了,話不多說(shuō),進(jìn)入正題。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • JS面試高頻單線程與事件循環(huán)深入解析

    JS面試高頻單線程與事件循環(huán)深入解析

    JavaScript是一種單線程語(yǔ)言,它在任何給定時(shí)間只能執(zhí)行一個(gè)任務(wù),然而js確能夠處理異步操作,這得益于其事件循環(huán)(Event Loop)機(jī)制,今天這篇文章帶領(lǐng)大家深入理解JavaScript單線程特性,以及講解事件循環(huán)和js多線程知識(shí)
    2023-10-10
  • JavaScript實(shí)現(xiàn)頁(yè)面5秒后自動(dòng)跳轉(zhuǎn)的方法

    JavaScript實(shí)現(xiàn)頁(yè)面5秒后自動(dòng)跳轉(zhuǎn)的方法

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)頁(yè)面5秒后自動(dòng)跳轉(zhuǎn)的方法,涉及javascript遞歸調(diào)用與計(jì)時(shí)函數(shù)setTimeout的使用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-04-04
  • Ajax實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)實(shí)例代碼

    Ajax實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)實(shí)例代碼

    這篇文章介紹了Ajax實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • Javascript中的基本類型和引用類型概述說(shuō)明

    Javascript中的基本類型和引用類型概述說(shuō)明

    這篇文章主要介紹了Javascript中的基本類型和引用類型的相關(guān)資料,包括基本類型和引用類型的概念及區(qū)別,數(shù)據(jù)類型檢測(cè)給大家詳細(xì)介紹了js基本類型和引用類型,非常不錯(cuò),需要的朋友可以參考下
    2022-11-11
  • 前端給后端傳數(shù)據(jù)的五種方式總結(jié)

    前端給后端傳數(shù)據(jù)的五種方式總結(jié)

    前端與后端數(shù)據(jù)交互是軟件開(kāi)發(fā)中不可或缺的一環(huán),下面這篇文章主要給大家介紹了關(guān)于前端給后端傳數(shù)據(jù)的五種方式,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-07-07
  • ionic實(shí)現(xiàn)可滑動(dòng)的tab選項(xiàng)卡切換效果

    ionic實(shí)現(xiàn)可滑動(dòng)的tab選項(xiàng)卡切換效果

    這篇文章主要為大家詳細(xì)介紹了ionic實(shí)現(xiàn)可滑動(dòng)的tab選項(xiàng)卡切換效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • p5.js入門教程之鼠標(biāo)交互的示例

    p5.js入門教程之鼠標(biāo)交互的示例

    這篇文章主要介紹了p5.js入門教程之鼠標(biāo)交互的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03

最新評(píng)論