5个很棒的JavaScript Promise函数应用

本文讨论了解决JavaScript中的异步问题,如取消请求、使用AbortController和信号控制fetch请求,以及在生产环境中等待和控制时间。同时,对React和Vue的异同,如虚拟DOM、组件化、状态管理和双向数据绑定进行了对比。
摘要由CSDN通过智能技术生成

取消获取请求

我们立即抱怨的一个问题是无法取消承诺。一个简单的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, …}

小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:前端)
img

react和vue的比较

相同
1)vitual dom
2)组件化
3)props,单一数据流

不同点
1)react是jsx和模板;(jsx可以进行更多的js逻辑和操作)
2)状态管理(react)
3)对象属性(vue)
4)vue:view——medol之间双向绑定
5)vue:组件之间的通信(props,callback,emit)

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

[外链图片转存中…(img-CF8tKIlx-1710586367337)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值