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

郑州建网站的好处智推教育seo课程

郑州建网站的好处,智推教育seo课程,惠山区住房和建设厅网站,工作表现情况怎么写async是为了解决异步操作,其实是一个语法糖,使代码书写更加简洁。 1. async介绍 async放在一个函数的前面,await则放在异步操作前面。async代表这个函数中有异步操作需要等待结果,在一个async函数中可以存在多个await&#xff0…

async是为了解决异步操作,其实是一个语法糖,使代码书写更加简洁。

1. async介绍

async放在一个函数的前面,await则放在异步操作前面。async代表这个函数中有异步操作需要等待结果,在一个async函数中可以存在多个await,也就是多个异步操作,但是需要注意的是await是一个一个发生的,执行完一个异步操作才会执行下一个异步操作,不是并发执行的。

async结果返回一个Promise对象,async结果状态变化可以由三种情况改变

第一种:函数体内有return,return的结果可以通过then方法获取。

第二种:如果await中的异步操作状态变为reject,则会将错误外抛,改变async的状态变为reject。

第三种:当所有await都执行完,并且状态为resolved,则状态会变为resolved,也就是只有所有异步操作执行完,才会执行then方法获取。

2. async可以使用在哪里?

  • 函数声明中
async function fun() {}
  • 函数表达式
const fun = async function() {}
  • 对象的方法
let obj = { async foo() {} };
obj.foo().then()
  • Class的方法
class Person{async age(num) {const a = await foo();}
}
const p1 = new Person();
p1.age(10).then();
  • 箭头函数

const foo = async () => {};

3. 使用

const f1 = async () => {await ab();
}
f1.then((resolve) => {console.log(resolve);
})

4. 错误处理

await后面一个Promise对象,如果不是则会立即转成Promise对象。

假如有问题的时候会向外抛出错误,会导致async状态变为reject。

假如我们不需要往外抛错误,可以使用try…catch或者在异步操作中添加catch方法,让错误及时处理掉,不往外抛。


async Function f1 () {await Promise.reject('出错了');await Promise.resolve('hello word'); // 不会执行了
}

由于抛出错误了,会整个async函数都会中断执行。


// 改成 第一种解决方法async Function f1 () {try {await Promise.reject('出错了');}catch (err){}return await Promise.resolve('hello word');
}f1.then(res => console.log(res)); // hello word// 第二种解决方法async Function f1 () {await Promise.reject('出错了').catch((err) => {console.log(err);})return await Promise.resolve('hello world');
}
f1.then(res => console.log(res)); // 出错了  hello word

5. 并发执行代码

正常情况下当async函数内部都多个await时,会执行完一个异步操作才会执行下一个异步操作,是继发执行,而不是并发执行,这样会很慢。

如果await后面的异步操作没有关联的话,则可以完全同时触发。

  • 第一种使用Promise.all()方法

let [foo, bar] = await Promise.all([getFoo(), getBar()]);
  • 第二种执行方法后await
let fooPromise = getFoo();
let barPromise = getBar();
let foo = await fooPromise();
let bar = await barPromise();

这样会同时触发异步操作,缩短执行时间。

  • 第三种 for循环、不能map循环
async function dbFuc (db) {let docs = [{}, {}, {}];let promises = docs.map(docs => db.post(doc));let results = [];for (let promise of promisees) {results.push(await promise);}console.log(results);
}
http://www.hkea.cn/news/14418/

相关文章:

  • 营销型网站与展示型网站bt种子搜索
  • 虚拟仿真实验室网站建设淘宝指数官网的网址
  • 企业网站管理系统湖南岚鸿种子资源
  • 手机代码网站有哪些问题吗沈阳关键字优化公司
  • 用php做网站视频百度统计数据
  • 网站建设中如何插入动图网站如何被搜索引擎收录
  • 猎头公司网站素材app代理推广合作50元
  • 计算机网站建设维护的基本知识星力游戏源码
  • 做文案选图片素材的网站昆明seo外包
  • 如何建设个人免费网站教程视频有哪些可以免费推广的平台
  • 专业网站托管外贸seo软件
  • 枣庄做网站做网站平台需要多少钱
  • dede关闭手机网站程序员培训机构哪家好
  • wordpress删除文章长治网站seo
  • 企业网站建设规划书个人网站首页设计
  • 承接做网站的网站外链
  • 网站制作培训班2022小说排行榜百度风云榜
  • wordpress 点击图片放大seow是什么意思
  • 网站建设需要会代码吗搜索引擎排名规则
  • 云南做网站报价产品推广渠道
  • 湖南网站制作电话互联网哪个行业前景好
  • 网站开发二线城市免费做网页的网站
  • wordpress 禁止保存seo网站自动发布外链工具
  • 网站模版的优化全国疫情最新报告
  • 企业网站开发报告网络营销的具体形式种类
  • 做网站找哪家好要钱吗自动搜索关键词软件
  • 沂水网站建设360搜索引擎
  • 60天做网站个人网站推广怎么做
  • wordpress文章接口网站关键词排名优化系统
  • 千山科技做网站好不好东莞网站seo公司哪家大