异步编程Promise,async,await
本文最后更新于 238 天前,其中的信息可能已经有所发展或是发生改变。

Promise

fetch 返回的就是 Promise

// fetch就是异步函数
fetch("http://127.0.0.1:4523/m1/2751993-0-default/project/list")
.then(function (response) {
    // console.log("response.json()", response.json())
    return  response.json()
})
.then(function (json) {
  console.log("json", json)
}
.catch(function (err){
  // 错误信息,出现错误之后,后面的then不会在执行,catch抛出错误信息
  console.log("err", err)
})
.finally(function (other) {
  // Promise结束后调用,无论失败与否
  // 可以执行一些清理工作
  // - 比如加载动画
  console.log("other", other)
})

// 类似同步编程中的 try...catch...

async,await

基于 Promise 的一个语法糖

await在等待的过程中js可以执行其他任务,这是因为 await 底层是基于 Promise 和事件循环机制实现的

// async 标记为异步函数
// 异步函数就是指返回值为 Promise 对象的函数
async function test(){
  const response = await fetch('http://127.0.0.1:4523/m1/2751993-0-default/project/list');
  // response返回的已经书服务器的数据了
  console.log("response", response)
  const json = await response.json()
  console.log("json", json)
}
test() // 注:这个值返回值永远是 Promise 对象

// await在等待的过程中js可以执行其他任务,这是因为 await 底层是基于 Promise 和事件循环机制实现的

  • 我们不能在全局或者普通函数中直接使用 await 关键字,会报错, “await“只在异步函数中有效
  • 如果我们想在最外层中使用 await, 那么需要先定义一个异步函数, 然后在函数体中使用它
async function f() {
  await someAsyncOperation();
}
f();

或者更简洁的写法

(async =>
await someAsyncoperation();
})();

参考

视频

文章

标题:异步编程Promise,async,await
地址:https://xiaodongxier.com/2065.html
作者:王永杰
暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇