摘要:本文讨论地址阅读时间大概分钟和有很多容易被忽视的不同之处。首先定义一个异步函数等待秒函数等待秒钟,然后有一半的概率返回,一半的概率抛出异常。这个是最符合我们预期的写法。
dev-reading/fe 是一个阅读、导读、速读的 repo,不要依赖于 dev-reading/fe 学习知识。本 repo 只是一个快速了解文章内容的工具,并不提供全文解读和翻译。你可以通过本平台快速了解文章里面的内容,找到感兴趣的文章,然后去阅读全文。
本文讨论地址:https://github.com/dev-readin...
阅读时间大概 2 分钟
await、return 和 return await 有很多容易被忽视的不同之处。
首先定义一个异步函数:
async function waitAndMaybeReject() { // 等待1秒 await new Promise(r => setTimeout(r, 1000)); const isHeads = Boolean(Math.round(Math.random())); if (isHeads) { return "yay"; } else { throw Error("Boo!"); } }
函数等待 1 秒钟,然后有一半的概率返回 "yay",一半的概率抛出异常。
1 直接调用 Just callingasync function foo() { try { waitAndMaybeReject(); } catch (e) { return "caught"; } }
直接调用 foo,函数总是返回 Promise fulfill with undefined, without waiting。
永远不会返回 "yay"。
2 Awaitingasync function foo() { try { await waitAndMaybeReject(); } catch (e) { return "caught"; } }
调用 foo,函数返回的 Promise 等待 1 秒,然后 fulfill with undefined, or fulfill with "caught"。
因为我们 await waitAndMaybeReject() 的结果,如果 rejected,我们的 catch 块捕获了异常,然后 "caught",如果 fulfilled,我们的函数并没有返回 Promise 的值。
3 Returningasync function foo() { try { return waitAndMaybeReject(); } catch (e) { return "caught"; } }
调用 foo,函数返回的 Promise 等待 1 秒,然后 fulfill with "yay", or reject with Error("Boo!")。
4 Return-awaitingasync function foo() { try { return await waitAndMaybeReject(); } catch (e) { return "caught"; } }
调用 foo,函数返回的 Promise 等待 1 秒,然后 fulfill with "yay", or fulfill with "caught"。
这个是最符合我们预期的写法。
我们可以把它拆分一下:
async function foo() { try { // 等待 waitAndMaybeReject() 函数的结果 // 把 fulfilled value 赋值给 fulfilledValue: const fulfilledValue = await waitAndMaybeReject(); // 如果 waitAndMaybeReject() 失败,抛出异常: return fulfilledValue; } catch (e) { return "caught"; } }
阅读原文:await vs return vs return await
讨论地址:await、return 和 return await 的陷阱 #12
如果你想参与讨论,请点击这里
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/92380.html
摘要:控制台将显示回调地狱通常,回调只能由一个异步函数调用。更多资源使更友好规范使用异步函数简化异步编码旅程异步编程是一项在中无法避免的挑战。 JavaScript经常声称是_异步_。那是什么意思?它如何影响发展?近年来这种方法有何变化? 请思考以下代码: result1 = doSomething1(); result2 = doSomething2(result1); 大多数语言都处理每...
摘要:控制台将显示回调地狱通常,回调只能由一个异步函数调用。更多资源使更友好规范使用异步函数简化异步编码旅程异步编程是一项在中无法避免的挑战。 JavaScript经常声称是_异步_。那是什么意思?它如何影响发展?近年来这种方法有何变化? 请思考以下代码: result1 = doSomething1(); result2 = doSomething2(result1); 大多数语言都处理每...
摘要:控制台将显示回调地狱通常,回调只能由一个异步函数调用。更多资源使更友好规范使用异步函数简化异步编码旅程异步编程是一项在中无法避免的挑战。 JavaScript经常声称是_异步_。那是什么意思?它如何影响发展?近年来这种方法有何变化? 请思考以下代码: result1 = doSomething1(); result2 = doSomething2(result1); 大多数语言都处理每...
阅读 2292·2023-04-26 00:28
阅读 3006·2019-08-30 15:55
阅读 2715·2019-08-30 12:47
阅读 1512·2019-08-29 11:04
阅读 3058·2019-08-28 18:14
阅读 920·2019-08-28 18:11
阅读 1635·2019-08-26 18:36
阅读 3354·2019-08-23 18:21