版本

no-async-promise-executor

禁止使用异步函数作为 Promise 执行器

推荐

配置文件中使用来自 @eslint/jsrecommended 配置将启用此规则。

new Promise 构造函数接受一个执行器函数作为参数,该函数具有 resolvereject 参数,可用于控制创建的 Promise 的状态。例如

const result = new Promise(function executor(resolve, reject) {
  readFile('foo.txt', function(err, result) {
    if (err) {
      reject(err);
    } else {
      resolve(result);
    }
  });
});

执行器函数也可以是async function。但是,这通常是一个错误,原因如下:

  • 如果异步执行器函数抛出错误,则该错误将丢失,并且不会导致新构造的Promise被拒绝。这可能使调试和处理某些错误变得困难。
  • 如果 Promise 执行器函数正在使用await,这通常表示实际上没有必要使用new Promise构造函数,或者可以缩小new Promise构造函数的范围。

规则细节

此规则旨在禁止异步 Promise 执行器函数。

此规则的错误代码示例

在游乐场中打开
/*eslint no-async-promise-executor: "error"*/

const foo = new Promise(async (resolve, reject) => {
  readFile('foo.txt', function(err, result) {
    if (err) {
      reject(err);
    } else {
      resolve(result);
    }
  });
});

const result = new Promise(async (resolve, reject) => {
  resolve(await foo);
});

此规则的正确代码示例

在游乐场中打开
/*eslint no-async-promise-executor: "error"*/

const foo = new Promise((resolve, reject) => {
  readFile('foo.txt', function(err, result) {
    if (err) {
      reject(err);
    } else {
      resolve(result);
    }
  });
});

const result = Promise.resolve(foo);

何时不使用它

如果您的代码库不支持async function语法,则无需启用此规则。

版本

此规则是在 ESLint v5.3.0 中引入的。

资源

更改语言