JavaScript异步函数
JavaScript的主要优势之一就是任何事情都是异步的。在大多数情况下,不同部分的代码不会影响共他的代码执行。
JavaScript的主要优势之一就是任何事情都是异步的。在大多数情况下,不同部分的代码不会影响共他的代码执行。
Chrome 55 中默认情况下启用异步函数,坦率地讲,它们的作用相当不可思议。 可以利用它们像编写同步代码那样编写基于 Promise 的代码,而且还不会阻塞主线程。 它们可以让异步代码“智商”下降、可读性提高。
众所周知,JavaScript 的执行环境是单线程的,所谓的单线程就是一次只能完成一个任务,其任务的调度方式就是排队,这就和火车站洗手间门口的等待一样,前面的那个人没有搞定,你就只能站在后面排队等着。在事件队列中加一个延时,这样的问题便可以得到缓解。
JS 中最基础的异步调用方式是 callback
,它将回调函数 callback
传给异步 API,由浏览器或 Node 在异步完成后,通知 JS 引擎调用 callback
。对于简单的异步操作,用 callback
实现,是够用的。但随着负责交互页面和 Node 出现,callback
方案的弊端开始浮现出来。 Promise 规范孕育而生,并被纳入 ES6 的规范中。后来 ES7 又在 Promise 的基础上将 async
函数纳入标准。此为 JavaScript 异步进化史。
对于 JavaScript 的异步编程我们早就谈得太多了,我们为了处理 Callback Hell
问题已经做了太多太多了,从 Promise 到 generator
再到 async/await
,JavaScript 这个惊天巨坑算是勉强填完了。关于 Promise 、 generator
以及 aysnc/await
这些具体的技术怎么用,这里就不细谈了,我们更多谈谈 “形而上” 的东西。
异步编程对JavaScript语言太重要。JavaScript语言的执行环境是“单线程”的,如果没有异步编程,根本没法用,非卡死不可。ES6将JavaScript异步编程带入了一个全新的阶段,ES7的Async
函数更是提出了异步编程的终极解决方案。
ES2017在6月份已经定稿,随之而来的是我最喜欢的JavaScript特性将得到广泛的支持:async
函数。如果你以前使用JavaScript的异步函数遇到过困难,那这个就是为您准备的。如果你没有,那么,你可能是这方面的高手。