Skip to content
← Back to rules

oxc/no-accumulating-spread 性能

它的作用

防止在 Array.prototype.reduce() 和循环中对累加器使用对象或数组展开。

为什么这是个问题?

对象和数组展开会在每次迭代时创建一个新对象或新数组。 最坏情况下,它们还会导致 O(n) 次复制(内存和时间复杂度均为 O(n))。 当在累加器上使用时,这可能导致 O(n^2) 的内存复杂度和 O(n^2) 的时间复杂度。

有关更深入的解释,请参阅 Prateek Surana 的这篇 博客文章

示例

以下为 错误 用法示例:

javascript
arr.reduce((acc, x) => ({ ...acc, [x]: fn(x) }), {});
Object.keys(obj).reduce((acc, el) => ({ ...acc, [el]: fn(el) }), {});

let foo = [];
for (let i = 0; i < 10; i++) {
  foo = [...foo, i];
}

以下为 正确 用法示例:

javascript
function fn(x) {
  // ...
}

arr.reduce((acc, x) => acc.push(fn(x)), []);
Object.keys(obj).reduce((acc, el) => {
  acc[el] = fn(el);
}, {});
// 尽可能避免展开非累加器,但此规则并不禁止
Object.keys(obj).reduce((acc, el) => {
  acc[el] = { ...obj[el] };
  return acc;
}, {});

let foo = [];
for (let i = 0; i < 10; i++) {
  foo.push(i);
}

如何使用

要通过配置文件或 CLI 启用 此规则,可以使用:

json
{
  "rules": {
    "oxc/no-accumulating-spread": "error"
  }
}
bash
oxlint --deny oxc/no-accumulating-spread

参考资料