技术资讯:一个Promise全新API,真好用!

大家好,我是大澈!

本文约800+字,整篇阅读大约需要1分钟。

感谢关注微信公众号:"程序员大澈",免费领取"面试礼包"一份,然后免费加入问答群,从此让解决问题的你不再孤单!

1. 资讯速览

最近,Promise 新出了一个方法,已经进入 Stage 3 (候选阶段) ,相信很快就能达到 Stage 4 (完成阶段),并在项目中广泛使用。

这个方法就是 Promise.withResolvers。它是一个静态方法,返回一个包含新的 Promise 对象和两个函数的对象。

其中,两个函数即:resolve 和 reject。分别对应于传递给 Promise 构造函数执行器的两个参数。

Promise.withResolvers 的关键点,在于现在解决和拒绝函数与 Promise 对象本身处于同一作用域,而不是在执行器中创建并且只能使用一次。

这使得在某些更高级的用例中可能会更加方便,例如:在重复事件中重用解决和拒绝函数,特别是在处理流和队列时。这也意味着嵌套层级较少,而不是在执行器中包含大量逻辑。

2. 资讯详细

先举例对比说明该方法的妙用,再补充一下注意点,最后做小结。

2.1 举例说明

在没有 Promise.withResolvers 之前,你可能实现了这样的代码:

js 复制代码
<script>
  let num = true;
  let resolve, reject;

  const promise = new Promise((res, rej) => {
      resolve = res;
      reject = rej;
  });

  num ? resolve("ok") : reject("not ok");
</script>

在使用 Promise.withResolvers 之后:

js 复制代码
<script>
  let num = true;

  const { promise, resolve, reject } = Promise.withResolvers();

  num ? resolve("ok") : reject("not ok");
</script>

很明显的发现,当我们单独使用 resolve 和 reject 时,用上 Promise.withResolvers ,不需要再定义一个额外的变量去存储。

2.2 注意点

该特性目前还在 Stage 3 阶段,预计2024年正式发版。

目前主流浏览器还没有全部支持该特性,谷歌需要 117以上的版本才能使用这个方法。

2.3 小结

Promise 新出了一个方法,已经进入 Stage 3 (候选阶段)。

它的关键点,在于现在解决和拒绝函数与 Promise 对象本身处于同一作用域,而不是在执行器中创建并且只能使用一次。

结语

建立这个平台的初衷:

  • 打造一个专注于前端功能问题的问答平台,让大家高效搜索处理同样问题。
  • 遇到有共鸣的问题,与众多同行朋友们一起讨论,一起沉淀成长。
  • 平台现拥有功能问题、技术资讯、实用干货3个专栏内容。

感谢关注微信公众号:"程序员大澈",免费领取"面试礼包"一份,然后免费加入问答群,从此让解决问题的你不再孤单!

相关推荐
皮皮大人14 分钟前
Vue 3 响应式内核完全解密:reactive & effect 与 Vue 2 Watcher 史诗对决
前端·vue.js
Xp0219110323 分钟前
知网研学、万方、WPS、大以论文四大排版工具横评,新用户免费排版等你领!
前端·css·html·生活·wps·论文排版
周凡12334 分钟前
AI 时代的 Web JavaScript 逆向分析实践与思考
前端·javascript·人工智能
zhoumeina991 小时前
分段创建产品,tab 页切换又要保留缓存
前端·javascript
The Sheep 20231 小时前
EFcore 查询数据
java·javascript
怕浪猫1 小时前
Electron 开发实战(七):网络通信与 API 集成全解
前端·javascript·electron
暗中讨饭xdm1 小时前
立体echarts柱状图咋做
前端·vue.js·echarts
w_t_y_y1 小时前
vue父子组件通信(一)父子调用和通信(2)VUE3
前端·javascript·vue.js
ZC跨境爬虫2 小时前
跟着 MDN 学CSS day_42:等分轨道、层叠放置与混合布局
前端·javascript·css·ui·html