#每日一记# 1分钟学会如何「便利地」使用 async/await
栏目: JavaScript · 发布时间: 7年前
内容简介:首先值得肯定的是在异步代码组织中在相同的作用域下可以调用异步返回值,这样的代码阅读起来更加符合直觉。但在异常处理的时候,
首先值得肯定的是在异步代码组织中 async/await
确实起到了很棒的作用,书写代码更加流畅。尤其是在作用域的处理上,让 异步返回值
和 异步函数调用时
的作用域保持相同。
// es5
// 假设 bar 函数返回一个有效的 promise
function foo () {
return bar().then(res => {
console.log(res); // 1
})
console.log(res); // error
}
复制代码
// es7
// 假设 bar 函数返回一个有效的 promise
async function foo () {
let res = await bar();
console.log(res); // 1
}
复制代码
在相同的作用域下可以调用异步返回值,这样的代码阅读起来更加符合直觉。
但在异常处理的时候, async/await
却变得异常复杂,本文就讲讨论如何尽可能优雅的优化这个问题。
异常处理
所谓成也萧何败也萧何,在 async/await
异常处理的时候需要引入 try/catch
来解决 程序异常
或者 reject
,但这又引入了一个子作用域干扰了代码的流畅性。
我们来看一点代码,我将展示 try/catch
是如何隐式的创建了一个新的作用域。
// es7
try {
let a = true;
} catch (e) {
let a = false;
}
console.log(a);
// ⬇编译后
// es5
"use strict";
try {
var _a = true; // 实际上 try catch 的花括号内是子作用域
} catch (e) {
var _a2 = false;
}
console.log(a); // error
复制代码
因为 try/catch
有隐式创建作用域的特性,这会让在花括号中申明的变量无法被外部访问到,这很容易让代码容易出错,并且书写起来很不流畅。
下面就是应用了 try/catch
的 async/await
函数。
// es7
// 假设 bar 函数返回一个有效的 promise
async function foo () {
let res, err;
try {
res = await bar();
} catch (e) {
err = e;
}
if (err) {
return 'error occur';
}
return res;
}
复制代码
利用解构
既然 try/catch
的作用域令人头疼,那么我们也可以利用 es6
中解构的特性来优化一下代码。
// es7
// 假设 bar 函数返回一个有效的 promise
async function foo () {
let [err, res] = await to(bar());
if (err) {
return 'error occur';
}
return res;
}
function to (promise) {
return promise
.then(res => {
return [null, res];
})
.catch(err => {
return [err];
})
}
复制代码
函数 to
帮我们把 promise
按照一个标准的格式返回一个数组,而这个数组最终都会使 promise
进入 resolve
状态,因此就可以避免使用 try/catch
结构。
如果在项目中,可以把函数 to
单独封装成一个模块使用。
// to.js
export default function to (promise) {
return promise
.then(res => {
return [null, res];
})
.catch(err => {
return [err];
})
}
复制代码
这篇文章是对 如何不用 try/catch 还能优雅使用 async/await (英文且需科学上网)这篇文章的实践和解读。
以上所述就是小编给大家介绍的《#每日一记# 1分钟学会如何「便利地」使用 async/await》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- tf46:再议tf.estimator之便利
- [译] 感受 4px 基线网格带来的便利
- 小卖柜亮相AWE,为便利购物创造更多可能
- Python的默认参数,为API设计带来了哪些便利
- 张利:见福便利店,蚂蚁雄兵的野蛮生命力
- Java RPC 框架 Solon 1.3.9 发布,更便利的支持
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
你也能看得懂的Python算法书
王硕,董文馨,张舒行,张洁 著 / 电子工业出版社 / 2018-11-1 / 59.00
编程的核心是算法,学习算法不仅能教会你解决问题的方法,而且还能为你今后的发展提供一种可能。 《你也能看得懂的Python算法书》面向算法初学者,首先介绍当下流程的编程语言Python,详细讲解Python语言中的变量和循序、分支、循环三大结构,以及列表和函数的使用,为之后学习算法打好基础。然后以通俗易懂的语言讲解双指针、哈希、深度优先、广度优先、回溯、贪心、动态规划和至短路径等经典算法。 ......一起来看看 《你也能看得懂的Python算法书》 这本书的介绍吧!