栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

为何流行的JavaScript运行时无法处理看起来像同步的异步脚本?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

为何流行的JavaScript运行时无法处理看起来像同步的异步脚本?

为什么不?没有理由,只是没有完成。

在2017年,它 在ES2017中完成:

async
函数可以用于
await
等待,无阻塞地等待承诺的结果。如果
getSomething
返回promise(请注意
await
)并且位于
async
函数内部,则可以这样编写代码:

try {    var foo = await getSomething();    var bar = doSomething(foo);      console.log(bar); } catch (error) {    console.error(error);}

(我曾假设您只打算

getSomething
异步,但两者都可能是异步的。)

实时示例(需要最新的浏览器,例如最新的Chrome):

function getSomething() {    return new Promise((resolve, reject) => {        setTimeout(() => { if (Math.random() < 0.5) {     reject(new Error("failed")); } else {     resolve(Math.floor(Math.random() * 100)); }        }, 200);    });}function doSomething(x) {    return x * 2;}(async () => {    try    {        var foo = await getSomething();        console.log("foo:", foo);        var bar = doSomething(foo);        console.log("bar:", bar);    }    catch (error)    {        console.error(error);    }})();The first promise fails half the time, so click Run repeatedly to see both failure and success.

您已用NodeJS标记了您的问题。如果将Node
API包装在Promise中(例如,使用promisify),则可以编写异步运行的漂亮的直接同步代码。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/391057.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号