有了promise为什么还要async、await

异步函数,也称为“async/await”(语法关键字),是 ES6 Promise 模式在 ECMAScript 函数中的应用。
async/await 是 ES8 规范新增的。这个特性从行为和语法上都增强了 JavaScript,让以同步方式写的代码能够异步执行。

下面来看一个最简单的例子,这个 Promise 在超时之后会处理为一个值:

let p = new Promise((resolve, reject) => setTimeout(resolve, 1000, 3));

这个 Promise 在 1000 毫秒之后处理为数值 3。如果程序中的其他代码要在这个值可用时访问它,则需要写一个解决处理程序:

let p = new Promise((resolve, reject) => setTimeout(resolve, 1000, 3));
p.then((x) => console.log(x)); // 3

这其实是很不方便的,因为其他代码都必须放到 Promise 处理程序中。不过可以把处理程序定义为一个函数:

function handler(x) { console.log(x); }
let p = new Promise((resolve, reject) => setTimeout(resolve, 1000, 3));
p.then(handler); // 3

这个改进其实也不大。这是因为任何需要访问这个 Promise 所产生值的代码,都需要以处理程序的形式来接收这个值。也就是说,代码照样还是要放到处理程序里。

ES8 为此提供了 async/await 关键字

你可能感兴趣的:(javascript,es6,node.js)