版本

no-sparse-arrays

禁用稀疏数组

推荐

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

稀疏数组包含空槽,最常见的原因是在数组字面量中使用了多个逗号,例如

const items = [,,];

虽然此示例中的 items 数组的 length 为 2,但实际上 items[0]items[1] 中没有值。 数组字面量仅包含逗号即可有效,再加上设置了 length 但未设置实际项目值,这使得稀疏数组对于许多开发人员来说令人困惑。 考虑以下情况

const colors = [ "red",, "blue" ];

在此示例中,colors 数组的 length 为 3。但是开发人员是否打算在数组中间有一个空位? 还是只是一个错别字?

以这种方式定义的稀疏数组引起的困惑足以建议避免使用它们,除非您确定它们在您的代码中很有用。

规则详情

此规则禁止使用稀疏数组字面量,这些字面量具有“空洞”,其中逗号前面没有元素。 它不适用于最后一个元素后面的尾随逗号。

此规则的错误代码示例

在 Playground 中打开
/*eslint no-sparse-arrays: "error"*/

const items = [,];
const colors = [ "red",, "blue" ];

此规则的正确代码示例

在 Playground 中打开
/*eslint no-sparse-arrays: "error"*/

const items = [];
const arr = new Array(23);

// trailing comma (after the last element) is not a problem
const colors = [ "red", "blue", ];

何时不使用

如果您想使用稀疏数组,那么禁用此规则是安全的。

版本

此规则在 ESLint v0.4.0 中引入。

延伸阅读

资源

更改语言