当前位置: 首页 > news >正文

自己做的产品在哪个网站上可从卖图片展示网站建设

自己做的产品在哪个网站上可从卖,图片展示网站建设,找网络公司做推广费用,志鸿优化网【作者主页】:小鱼神1024 【擅长领域】:JS逆向、小程序逆向、AST还原、验证码突防、Python开发、浏览器插件开发、React前端开发、NestJS后端开发等等 async/await 是 ECMAScript 2017 标准中引入的一种用于处理异步操作的语法糖。它基于 Promise 和 Gen…

【作者主页】:小鱼神1024

【擅长领域】:JS逆向、小程序逆向、AST还原、验证码突防、Python开发、浏览器插件开发、React前端开发、NestJS后端开发等等

async/await 是 ECMAScript 2017 标准中引入的一种用于处理异步操作的语法糖。它基于 Promise 和 Generator,并提供了一种更简洁、更直观的方式来编写异步代码。

async/await 的基本用法

定义一个异步函数,使用 async 关键字修饰函数声明

async function fetchData() {// 异步操作的代码
}

在异步函数内部,使用 await 关键字等待一个 Promise 对象的完成,并将其结果返回

async function fetchData() {const result = await someAsyncOperation();// 使用 result 处理异步操作的结果
}

在异步函数内部,使用 try…catch… 语句处理异步操作的错误

async function fetchData() {try {const result = await someAsyncOperation();// 使用 result 处理异步操作的结果} catch (error) {// 处理异步操作的错误}
}

async/await 案例

::: warning 注意事项

  • 如果要使用 await ,其所在的函数前要加上 async
  • 如果函数用 async "修饰"过,其函数本身就是 Promise ,可以使用.then 方法操作
  • 如果要捕获错误,可以用 try catch
    :::
async function fetchData() {try {const response = await fetch("https://api.example.com/data");const data = await response.json();// 处理获取到的数据return data;} catch (error) {// 处理错误throw new Error("Failed to fetch data");}
}async function main() {try {const data = await fetchData();// 使用获取到的数据console.log(data);} catch (error) {// 处理错误console.error(error);}
}main();

async/await 实现原理分析

async/await 的实现原理可以简单概括为以下几个步骤:

  • 将异步函数转换为一个返回 Promise 的普通函数:当定义一个异步函数时,JavaScript 引擎会将其转换为一个普通函数,该函数返回一个 Promise 对象。这个 Promise 对象表示异步操作的最终结果。
  • 使用 Generator 函数实现暂停和恢复:在异步函数内部,使用 Generator 函数来实现暂停和恢复的功能。Generator 函数是一种特殊的函数,可以通过 yield 关键字将函数的执行暂停,并通过 next() 方法将函数的执行恢复。
  • 使用 Promise 对象管理异步操作的状态:在异步函数内部,使用 Promise 对象来管理异步操作的状态。当遇到 await 关键字时,会将后面的表达式转换为一个 Promise 对象,并等待该 Promise 对象的状态变为完成。如果 Promise 对象的状态变为拒绝,会抛出一个错误。
  • 通过递归调用实现异步操作的串行执行:在异步函数内部,通过递归调用来实现异步操作的串行执行。当遇到 await 关键字时,会等待前一个异步操作完成后再执行下一个异步操作。

总的来说,async/await 的实现原理是基于 Promise 和 Generator 函数的组合使用。它通过将异步操作转换为 Promise 对象,并使用 Generator 函数来实现暂停和恢复的功能,从而实现了以同步的方式编写异步代码的效果。

function delay(ms) {return new Promise((resolve) => setTimeout(resolve, ms));
}async function fetchData() {try {console.log("Fetching data...");await delay(2000); // 模拟异步操作console.log("Data fetched!");return "Data";} catch (error) {console.error("Failed to fetch data:", error);throw error;}
}async function main() {try {console.log("Start");const data = await fetchData();console.log("Received:", data);console.log("End");} catch (error) {console.error("Error:", error);}
}main();

async/await 与 Promise 的区别

  • async/await 是基于 Promise 实现的,它们的行为基本相同
  • async/await 使得异步代码看起来像同步代码,这正是它的魔力所在
  • async/await 使得异步代码的异常处理变得更加简单

创作不易,动动您发财的小手,点赞关注一波,支持我创作更多对您有帮助的文章!

http://www.yayakq.cn/news/566140/

相关文章:

  • 沣东新城开发建设集团有限公司网站软媒win7优化大师
  • 刚做的网站怎么在百度搜到360网站seo手机优化软件
  • 域名申请好了 怎么做网站北京网站设计网站公司
  • 的网站建设oa软件开发公司
  • 宁波p2p网站建设 align center
  • 网站建设的教学设计快速制作效果图软件
  • 中国招标机构哪个网站做的好如何给企业做网络推广
  • wordpress 中介网站义乌市场官方网站
  • 有限责任公司是什么意思网站优化+山东
  • 网站放假通知人是用什么做的视频网站吗
  • 去后台更新一下网站wordpress企业站制作
  • 长沙网站制作网站开发的最后5个阶段
  • 重庆市住房城乡建设网站女教师网课入侵录屏冫
  • 人力资源公司网站建设造价企业怎么登陆建设部网站
  • 维护网站要做哪些工作win主机wordpress重定向
  • 淘宝运营培训班去哪里学杭州关键词优化平台
  • 有些网站突然无法访问学做网站论坛vip学员码
  • 昌平网站制作阿里云建站套餐
  • 双语版网站怎么做企业所得税税率2019
  • 表格如何给网站做链接地址内蒙古建设厅公示网站
  • 网站可视化后台电商网店开店全过程
  • 怎么用wordpress搭建网站一个公司可以做两个网站推广吗
  • 教育类的网站方案昆明做网站的旅行社
  • c2c网站代表和网址做怎么网站收费
  • 做购物商城类网站需要iis 网站关闭
  • 网站开发 微信收款湛江廉江网站建设
  • 公司网站管理做网站书面报告申请
  • 大连教育培训网站建设全国网站打开速度
  • 软件外包项目网站论坛类的网站怎样做
  • 路飞和女帝做h的网站开发定制电商平台