返回博主主页

await等待结果总结

通常await等的是一个promise(也就是包含异步操作,如果是普通值的话,等到的就是原始值)。
等待promise分为以下几种情况:

  • promise resolve后没有then方法,那么等到的就是传给resolve的值
复制代码
function hai () {
    return new Promise((reslove, reject) => {
         setTimeout(() => {
             reslove('hai')
         }, 1000)
    })
}
async function waitMe() {
 let a = await hai() // 
 let b=await 1
 console.log(a) // hai
 console.log(b)// 1
}
复制代码
  • promise 有then 方法,则等到的是then方法回调函数的返回值。如果then没有返回值则等到的是undefined
复制代码
function hai () {
    return new Promise((reslove, reject) => {
         setTimeout(() => {
             reslove('hai')
         }, 1000).then((x)=>x+'then')
    })
}
async function waitMe() {
 let a = await hai() // 
 console.log(a) // haithen
}
复制代码
复制代码
function hai () {
    return new Promise((reslove, reject) => {
         setTimeout(() => {
             reslove('hai')
         }, 1000).then((x)=>{var x=1})
    })
}
async function waitMe() {
 let a = await hai() // 
 console.log(a) // undefined
}
复制代码

 


                  

posted @   懒惰的星期六  阅读(466)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构

Welcome to here

主页
点击右上角即可分享
微信分享提示