5个很棒的JavaScript Promise函数应用

星标公众号 前端开发博客,回复“加群”

加入我们一起学习,天天进步

Promise API改变了JavaScript的游戏。我们从滥用settimeout和解决同步操作到尽一切可能利用这个新的异步API。让我们来看看一些令人敬畏的Promise API技巧!

取消获取请求

我们立即抱怨的一个问题是无法取消承诺。一个简单的promiseInstance.cancel()本来是很好的选择,但没有出现。相反,我们得到的是一个更为复杂的API:

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 requestcontroller.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承诺是我们每天都要做的事情,但更广泛地看待它们会让我们有所创新!你有自己的承诺技巧吗?

关于本文

http://www.fly63.com/article/detial/10370

相关文章

  1. Javascript 里的奇葩知识

  2. 由浅入深,66条JavaScript面试知识点

  3. 20个常用的JavaScript简写技巧

最后

转发文章并关注公众号:前端开发博客,回复 1024,领取前端进阶资料

  1. 回复「电子书」领取27本精选电子书

  2. 回复「加群」加入前端大神交流群,一起学习进步

  3. 回复「JS」获取 JavaScript 精选文章

分享和在看就是最大的支持❤️

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值