在这模拟一个向服务发起请求的例子
-
new
Promise(
(resolve, reject) => {
-
setTimeout(
() => {
-
const res =
'这是反馈的信息'
-
if (
1 >
2) {
-
resolve(res)
-
}
else {
-
reject(
'其他的信息')
-
}
-
},
1000)
-
}).then(
-
(res) => {
-
console.log(
`sucesss:${res}`)
-
},
-
(err) => {
-
console.log(
`error:${err}`)
-
}
-
)
当我们用上了 async 和 await,就需要写成下面这样:
-
function asyncDemo() {
-
return
new
Promise(
(resolve, reject) => {
-
setTimeout(
() => {
-
const res =
'这是反馈的信息'
-
if (
1 >
2) {
-
resolve(res)
-
}
else {
-
reject(
'其他的信息')
-
}
-
},
1000)
-
})
-
}
-
-
async
function demo() {
-
try {
-
const res =
await asyncDemo()
-
}
catch (err) {
-
console.log(err)
-
}
-
}
-
-
demo()
在这里 加上了 try... catch..,是不是 觉得更繁琐了呢,MDN给出了他的解释:
如果你在代码中使用了异步函数,就会发现它的语法和结构会更像是标准的同步函数。
说白了,这种写法的一部分原因,就是为了“讨好” Java 和其他的一些程序员。
另一方面呢,也是增强可读性,虽然说 async await 的写法比较丑,但是毫无疑问,可读性远远高于 Promise then。
最为重要的呢,是 Promise 可以无限嵌套,而 async await 只能处理一个 Promise,无法继续嵌套。
所以一旦需要使用多次连续回调,async await 就乏力了。
其实也可以,通过 await 一个Promise.all()来实现。
转载:https://blog.csdn.net/weixin_43844696/article/details/106467500
查看评论