1.async 函数是什么?一句话,它就是 Generator 函数的语法糖。

const fs = require('fs');

const readFile = function (fileName) {
return new Promise(function (resolve, reject) {
fs.readFile(fileName, function(error, data) {
if (error) return reject(error);
resolve(data);
});
});
}; //Generator 函数
const gen = function* () {
const f1 = yield readFile('/etc/fstab');
const f2 = yield readFile('/etc/shells');
console.log(f1.toString());
console.log(f2.toString());
}; //async函数
const asyncReadFile = async function () {
const f1 = await readFile('/etc/fstab');
const f2 = await readFile('/etc/shells');
console.log(f1.toString());
console.log(f2.toString());
};

async函数就是将 Generator 函数的星号(*)替换成async,将yield替换成await,async函数的返回值是 Promise 对象,这比 Generator 函数的返回值是 Iterator 对象方便多了。你可以用then方法指定下一步的操作。进一步说,async函数完全可以看作多个异步操作,包装成的一个 Promise 对象,而await命令就是内部then命令的语法糖。

2.async 函数有多种使用形式

// 函数声明
async function foo() {} // 函数表达式
const foo = async function () {}; // 对象的方法
let obj = { async foo() {} };
obj.foo().then(...) // Class 的方法
class Storage {
constructor() {
this.cachePromise = caches.open('avatars');
} async getAvatar(name) {
const cache = await this.cachePromise;
return cache.match(`/avatars/${name}.jpg`);
}
} const storage = new Storage();
storage.getAvatar('jake').then(…); // 箭头函数
const foo = async () => {};

3.只有async函数内部的异步操作执行完,才会执行then方法指定的回调函数

async function getTitle(url) {
let response = await fetch(url);
let html = await response.text();
return html.match(/<title>([\s\S]+)<\/title>/i)[1];
}
getTitle('https://tc39.github.io/ecma262/').then(console.log);

上面代码中,函数getTitle内部有三个操作:抓取网页、取出文本、匹配页面标题。只有这三个操作全部完成,才会执行then方法里面的console.log

4.按顺序完成异步操作,依次远程进行ajax请求,然后按照请求的顺序输出结果

let urls = [
'https://www.easy-mock.com/mock/5c73528306ffee27c6b2f0aa/testAerial/pointarr',
'https://www.easy-mock.com/mock/5b62549fbf26d2748cff3cf4/dashuju/visualize'
]; async function loader1(urls){//所有远程操作都是继发。只有前一个 URL 返回结果,才会去读取下一个 URL
for(let url of urls){
const response = await $.getJSON(url).then((res) => res);
console.log(response);//ajax先后请求并返回结果
}
}
loader1(urls);

5.并发发出远程ajax请求,同时输出结果

let urls = [
'https://www.easy-mock.com/mock/5c73528306ffee27c6b2f0aa/testAerial/pointarr',
'https://www.easy-mock.com/mock/5b62549fbf26d2748cff3cf4/dashuju/visualize'
]; async function loader(urls){//map方法的参数是async函数,但它是并发执行的,因为只有async函数内部是继发执行,外部不受影响。后面的for..of循环内部使用了await,因此实现了按顺序输出
const results = urls.map(async url => {
const response = await $.getJSON(url).then((res) => res);
return response;
}); for(let text of results){
console.log(await text);//ajax一起请求同时返回结果
} }
loader(urls);

6.异步遍历器与同步遍历器

const asyncIterable = createAsyncIterable(['a', 'b']);
const asyncIterator = asyncIterable[Symbol.asyncIterator]();//部署异步遍历器接口 asyncIterator
.next()
.then(iterResult1 => {
console.log(iterResult1); // { value: 'a', done: false }
return asyncIterator.next();
})
.then(iterResult2 => {
console.log(iterResult2); // { value: 'b', done: false }
return asyncIterator.next();
})
.then(iterResult3 => {
console.log(iterResult3); // { value: undefined, done: true }
});
let arr = ['a', 'b', 'c'];
let iter = arr[Symbol.iterator]();//部署同步遍历器 iter.next() // { value: 'a', done: false }
iter.next() // { value: 'b', done: false }
iter.next() // { value: 'c', done: false }
iter.next() // { value: undefined, done: true }

备注:文中多数内容摘自阮一峰老师文章,仅供自我学习查阅。

最新文章

  1. Django基础,Day3 - 编写 django admin
  2. 第0/24周 SQL Server 性能调优培训引言
  3. Java GC回收机制
  4. MySQL主键删除/添加
  5. word2007 每页显示表头
  6. 【Java基础】String StringBuffer StringBuilder
  7. 如果你也打算学习 Spring Cloud
  8. HBuilder git合作-从Git Hub Clone项目
  9. Thread.join(), CountDownLatch、CyclicBarrier和 Semaphore区别,联系及应用
  10. es6的let,const
  11. linux命令 xxd
  12. Learning to Promote Saliency Detectors
  13. Django学习手册 - 连接mysql数据库
  14. swift3.0自定义相机界面
  15. Linux - 变量的查看与设置
  16. 让DOM从页面中消失的方法
  17. win10 任务栏锁定,win键没反应
  18. L1-025 正整数A+B(15)(思路+测试点分析)
  19. JMeter安装+配置+运行
  20. python 数据类型-字符串-对象和方法

热门文章

  1. Python : TypeError: &#39;int&#39; object is not iterable
  2. Python爬虫--淘宝“泸州老窖”
  3. C# .NET Core 3.1中使用 MongoDB.Driver 更新嵌套数组元素和关联的一些坑
  4. 配置pyenv环境
  5. 基于JWT的Token身份验证
  6. [对对子队]会议记录4.18(Scrum Meeting9)
  7. 2019.03.27【GDOI2019】模拟 T3
  8. Linux下Zabbix5.0 LTS监控基础原理及安装部署(图文教程)
  9. systemverilog 字符串类型
  10. AXI总线简介、ID分析、DMA、Vivado烧录、系统集成