Promise.withResolvers() vs 传统 Promise:谁更胜一筹?

前言

介绍个 ES 新特性。

之前我们要返回promiseresolvereject出去,就会用这种定义变量的方法,以前就是这些写,在Promise外面定义两个变量,然后在这个构造器里面,给它赋值:

js 复制代码
let resolve, reject;

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

然后在别的函数的地方去调用这个函数,以及promise的resolve和reject。


正文

现在有语法糖可以同样做到这种返回promiseresolvereject这种写法了。

就是Promise.withResolvers()这个。

Promise.withResolvers()静态方法返回一个对象,其包含一个新的Promise对象和两个函数。

语法

js 复制代码
Promise.withResolvers()

返回值

这个静态方法呢,它就会返回一个对象,这个对象里边有三个属性啊。你可以把它解构出来一个,就是我们的promise,它就是用来得到一个promise的。然后呢,是跟这个promise相关的resolve和reject。

1、promise: 一个Promise对象。

2、resolve

3、reject

上面那个返回resolve和reject的写法,可以换成这种:

js 复制代码
const { promise, resolve, reject } = Promise.withResolvers() 

底层核心代码

js 复制代码
Promise.withResolvers = function () {
  let resolve, reject
  const promise = new Promise((_resolve, _reject) => {
    [resolve, reject] = [_resolve, _reject]
  })
  
  return { promise, resolve, reject }
}

例子

js 复制代码
const { promise, resolve, reject } = Promise.withResolvers() // 这里相当于手动创建了`Promise`,并且提取出`resolve`和`reject`。

// 1秒后,调用`resolve('成功!')`,`promise`状态从`pending`变为`fulfilled`,并携带值`成功!`
setTimeout(() => {
  resolve('成功!')
}, 1000)

promise.then(value => {
  console.log(value) // `promise.then`监听`Promise`完成。`then`注册的回调会在`promise`被`resolve`后执行,并接收`resolve`传递的值`成功!`。
})

执行顺序:

  1. 创建 Promisepromise 初始状态为 pending
  2. 设置定时器 :1 秒后执行 resolve('成功!')
  3. 监听 Promisethen 注册回调,等待 promise 完成。
  4. 1 秒后
    • resolve('成功!') 被调用,promise 变为 fulfilled
    • then 的回调执行,打印 "成功!"

输出:

复制代码
成功!  (1秒后打印)

对比传统写法:

javascript 复制代码
let resolve; // 传统方式需要外部变量
const promise = new Promise((res) => {
  resolve = res;
});

setTimeout(() => {
  resolve('成功!');
}, 1000);

promise.then(console.log); // "成功!"

总结

Promise.withResolvers() 更简洁,无需手动管理外部变量。

相关推荐
知识分享小能手1 小时前
React学习教程,从入门到精通, React 属性(Props)语法知识点与案例详解(14)
前端·javascript·vue.js·学习·react.js·vue·react
魔云连洲1 小时前
深入解析:Vue与React的异步批处理更新机制
前端·vue.js·react.js
mCell1 小时前
JavaScript 的多线程能力:Worker
前端·javascript·浏览器
超级无敌攻城狮3 小时前
3 分钟学会!波浪文字动画超详细教程,从 0 到 1 实现「思考中 / 加载中」高级效果
前端
excel4 小时前
用 TensorFlow.js Node 实现猫图像识别(教学版逐步分解)
前端
gnip4 小时前
JavaScript事件流
前端·javascript
赵得C4 小时前
【前端技巧】Element Table 列标题如何优雅添加 Tooltip 提示?
前端·elementui·vue·table组件
wow_DG4 小时前
【Vue2 ✨】Vue2 入门之旅 · 进阶篇(一):响应式原理
前端·javascript·vue.js
weixin_456904274 小时前
UserManagement.vue和Profile.vue详细解释
前端·javascript·vue.js
资深前端之路4 小时前
react 面试题 react 有什么特点?
前端·react.js·面试·前端框架