Skip to content
← Back to rules

unicorn/prefer-object-from-entries Style

🚧 An auto-fix is planned for this rule, but not implemented at this time.

它的作用

鼓励在将键值对数组转换为对象时使用 Object.fromEntries

为什么这不好?

使用 reduceforEach 手动根据键值对构建对象更加冗长、容易出错,也更难理解。Object.fromEntries 方法更清晰、更具声明性,并且就是为此目的而设计的。

示例

以下是此规则的错误代码示例:

js
const result = pairs.reduce((obj, [key, value]) => {
  obj[key] = value;
  return obj;
}, {});

const result = {};
pairs.forEach(([key, value]) => {
  result[key] = value;
});

以下是此规则的正确代码示例:

js
const result = Object.fromEntries(pairs);

配置

此规则接受一个包含以下属性的配置对象:

functions

type: string[]

default: ["_.fromPairs", "lodash.fromPairs"]

要视为 Object.fromEntries 等价项的其他函数。

如何使用

To enable this rule using the config file or in the CLI, you can use:

json
{
  "rules": {
    "unicorn/prefer-object-from-entries": "error"
  }
}
ts
import { defineConfig } from "oxlint";

export default defineConfig({
  rules: {
    "unicorn/prefer-object-from-entries": "error",
  },
});
bash
oxlint --deny unicorn/prefer-object-from-entries

版本

此规则于 v0.16.12 中添加。

参考资料