首页 > 编程语言 > 详细

JavaScript运行机制(四)promise与async函数

时间:2021-07-28 18:12:13      阅读:14      评论:0      收藏:0      [点我收藏+]

promise和async函数

promise
  let p = new Promise((resolve)=>{
    resolve("hello world")
  })

  p.then((data) => {
    console.log(data) // hello world
  })
async函数
// async函数的返回值是promise对象
  async function fun(){
    return 1
  }
  let a = fun()
  console.log(a) // Promise { 1 }
  fun().then((data)=>{
    console.log(data) // 1
  })

await
  let p1 = new Promise((resolve) => {
    resolve(1)
  })

  let p2 = new Promise((resolve) => {
    resolve(2)
  })

  async function fun(){
    let a = await p1
    let b = await p2
    console.log(a) // 1
    console.log(b) // 2
  }

  fun()
  async function fun1(){
    let data = await fun2()
    console.log(data) // 相当于then中的代码
  }
  async function fun2(){
    console.log(data) // 同步
    return 100
  }
  fun1()
  // 执行顺序是 200 100 
例子-执行顺序
  console.log(1)
  async function async1(){
    await async2()
    console.log(2)
  }
  async function async2(){
    console.log(3)
  }
  async1()
  setTimeout(function () {
    console.log(4)
  },0)
  new Promise((resolve)=>{
    console.log(5)
    resolve()
  }).then(()=>{
    console.log(6)
  }).then(()=>{
    console.log(7)
  })
  console.log(8)
  // 1358267
  1. 同步
  2. process.nextTick
  3. 微任务(promise.then)
  4. 宏任务(计时器,ajax,读取文件)
  5. setImmediate

JavaScript运行机制(四)promise与async函数

原文:https://www.cnblogs.com/duet/p/15068260.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!