在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問答/網(wǎng)絡(luò)安全  HTML/ 關(guān)于async函數(shù)的一個奇怪的問題

關(guān)于async函數(shù)的一個奇怪的問題

今天在看async函數(shù)時寫了一個函數(shù),原本的想法是執(zhí)行Func,3秒鐘之后返回一個promise對象的值為20,但是結(jié)果每次打印的值都不一樣,基本在9~13,然后我用setInterval持續(xù)打印,每次的結(jié)果都在上次的結(jié)果上+1。。。
后來改了之后對了,但是對改動前這個函數(shù)的結(jié)果非常好奇,大家可以試一下改動前的函數(shù),希望幫忙解答一下,跪謝~。
(PS:我在chrome控制臺執(zhí)行這個函數(shù),不同頁面的控制臺下初始值和遞增值都不一樣,這又是為什么)

改動前:

  async function Func(){
        let b = 0
        b = await setTimeout(function(){return 20},3000)
        return b
      }
      
  setInterval(()=>{Func().then(res=>console.log(res))},1000)//依次為12,13,14,15...

改動后:

 async function Func(){
        let b = 0
        b = await new Promise((resolve,reject)=>{
            setTimeout(function(){resolve(20)},3000)
        })
        return b
      }
 Func().then(res=>console.log(res))// 20
  
回答
編輯回答
雨萌萌

因為 setTimeout() 不是異步函數(shù), await 對它沒作用的

  async function Func(){
        let b = 0
        b = await setTimeout(function(){return 20},3000)
        return b // 這一行并不會 3 秒后才執(zhí)行,而是立即執(zhí)行
      }
      
  setInterval(()=>{Func().then(res=>console.log(res))},1000)//依次為12,13,14,15...

至于為什么是 12, 13, 14, 15,那是因為 setTimeout() 本身是有返回值的,通常是從 1 開始遞增的數(shù)字。

2017年7月19日 17:19