5个很棒的JavaScript Promise技巧
来源 | http://www.fly63.com/article/detial/10370
const controller = new AbortController();
const { signal } = controller;
fetch("http://localhost:8000", { signal }).then(response => {
console.log(`Request 1 is complete!`);
}).catch(e => {
console.warn(`Fetch 1 error: ${e.message}`);
});
// Abort request
controller.abort();
这里的神奇之处在于为每个fetch请求提供信号。在JavaScript世界中,我们继承了困难的API,并对它们进行了奇妙的抽象,因此我们将找到一种方法来更好地抽象这个API。
等待时间,永远等待
等待一段时间在大量生产和测试情况下是很有用的——这并不理想,但总是有帮助的。我用了两个很棒的功能让我的生活变得更好:
/* Wait for milliseconds */
function waitForTime(ms) {
return new Promise(r => setTimeout(r, ms));
}
/* Usage */
await waitForTime(200);
/* Wait Forever */
function waitForever() {
return new Promise(r => {});
}
// Usage:
await waitForever();
不要等待完美的情况,等待你需要的时间。
异步数组函数
像forEach、map和其他函数这样的数组函数经常被使用,而不需要它们是同步的。我们不去想它有相当多的时间我们可以在我们的操作中实现异步。
const promises = [1, 2, 3].map(async (num) => {
console.log(num);
});
await promises;
异步和同步的区别是有承诺的。当你可以的时候,去异步!
然后在对象
您知道可以在对象上任意添加一个then方法来将它们作为Promise处理吗?
j = { then: resolve => fetch("/").then(resolve) }
j.then(res => console.log(res));
// Response {type: "basic", url: "https://davidwalsh.name/", redirected: false, status: 200, ok: true, …}
// ... or an await...
const response = await j;
// Response {type: "basic", url: "https://davidwalsh.name/", redirected: false, status: 200, ok: true, …}
现在你知道!一个大多数人都不知道的绝妙把戏!
检测异步函数
这不是你经常需要做的事情,但这篇文章是关于技巧的,对吗?如果你想检测一个异步函数,你总是可以:
async function myFunction() {
}
const isAsync = myFunction.constructor.name === "AsyncFunction";
JavaScript承诺是我们每天都要做的事情,但更广泛地看待它们会让我们有所创新!你有自己的承诺技巧吗?
学习更多技能
请点击下方公众号
评论