ajax的asnyc,async和ajax的同步请求的区别

async await 是 promise.then 的一种写法,他并不是阻塞线程,而ajax的同步请求是阻塞线程的。

async asyncFunction = function() {

let a = await new Promise(resolve => {

setTimeout(() => {

console.log('asyncFunction')

resolve()

}, 1000)

})

}

let fatherFunction = {

console.log('fatherFunction')

asyncFunction()

console.log('after async')

}

let main = function() {

fatherFunction()

console.log('main')

}

main()

上面的代码执行的结果是:

bVbIkPT

可以看到 asyncFunction 在 main 打印了之后才打印的,说明 asyncFunction 实际上还是一个异步的请求,他并不会阻塞 main 函数的执行。

另外我们看到 after async 在 asyncFunction 之后才打印,其实不用过多的解释,我们把 fatherFunction 和 asyncFunction 换一种写法就明白了

asyncFunction = function() {

let a = new Promise(resolve => {

setTimeout(() => {

console.log('asyncFunction')

resolve()

}, 1000)

})

}

fatherFunction() {

console.log('fatherFunction')

asyncFunction().then(() => {

console.log('after async')

})

}

因为 async await 实际上就是为了不用一直写 then(),用同步的写法让函数表达更直观,实际还是异步。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值