ESLint 检测小技巧

阅读时长 4 分钟读完

介绍

在前端开发中,代码质量一直是比较重要的一个话题。而 ESLint 正是一个可以帮助我们保持代码质量的工具。ESLint 是一个插件化的 JavaScript 代码静态分析工具,它可以帮助我们发现代码中的潜在问题、规范代码风格,并提供一定的纠正能力。在团队协作开发的过程中,ESLint 的作用也不可小觑。

ESLint 常见问题

在使用 ESLint 过程中,我们可能会遇到下面这些问题:

  1. 代码检测规则太多,不知道从哪里开始;
  2. 部分代码不符合我们的 ESLint 规则,但我们又不想直接注释掉;
  3. 某些代码符合规则,但我们不确定它是好的。

下面我们将介绍一些针对上述问题的技巧。

技巧一:增量引入规则

一些项目中可能有几千条 ESLint 规则,每次在一个项目中集成这些规则非常困难,因为需要从我们现有的代码库中删除成百上千的错误。因此,我们需要一种逐步引入规则的方式,而不是迫使他们全部生效在一开始。

为了使这种增量维护变得容易,我们可以使用根目录下的.eslintignore文件和.eslint.js文件中的配置项。.eslintignore文件可用于忽略某个目录或文件。在.eslint.js文件中将需要的规则导出并使用配置就可以了。

-- -------------------- ---- -------
-------------- - -
  -------- -------------- --------------
  -------- ---------------------- --------------------------
  ------ -
    ----------- -------
    ----------- --------
    ---------------------- -------
    ---------------------- --------
    ------------------------ -------
  --
--

在这个例子中,rules对象只包含我们想要使用的规则。任何在 object 中没有列出的规则都将被省略。

技巧二:使用 ESLint 注释

我们可能会遇到一些情况,某些规则并不能直接应用在我们的代码上。但我们不希望改变规则,也不想有警告信息,这时可以使用 ESLint 注释。

注释的语法和 C/C++ 风格的注释一致,比如:

以及:

这个例子中,规则 no-console 被禁用直到该文件的末尾。该规则将在下面的代码中重新生效。

技巧三:找到好坏代码

如果某段代码如何符合我们的代码风格,以及它是否符合其性质的行为则需要更深入的了解。对于这种情况,ESLint 设计了一个自动分析工具叫做 eslint-plugin-eslint-comments。该插件可帮助您寻找我们自己注释的位置,以及一个样式和行为指南,以最大程度地确保我们自己和我们的团队能够保持代码的一致性。

安装该插件后,在.eslint.js文件中的配置中引用即可。

-- -------------------- ---- -------
-- ----------
-------------- - -
  ---
  -------- --------------------
  ------ -
    ---------------------------------------- --------
    --------------------------------------- --------
    --------------------------------------- --------
    ------------------------------------ -------
    ----------------------------------- -------
  --
--

在这个例子中,我们使用了由 eslint-plugin-eslint-comments 提供的规则。下面列出了这些规则的作用:

  • no-aggregating-enable:禁止在同一块注释中使用多个 eslint-enable;
  • no-duplicate-disable:禁止使用两次注释;
  • no-unlimited-disable:禁止使用永久禁止规则生成的注释;
  • no-unused-disable:查找注释无用的情况;
  • no-unused-enable:查找启用但未使用的注释。

总结

在这篇文章中,我们介绍了一些 ESLint 方面的小技巧,以解决一些常见的问题。 还有很多优秀的 ESLint 插件和扩展库,可以进一步完善我们的前端开发体验。值得一提的是,除了 ESLint,还有更多的代码质量工具,比如 Prettier 可以帮助我们格式化代码。在项目开发前期,可以进行代码规范的制订,并结合代码质量工具来实现。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/6533d2237d4982a6eb7714eb

纠错
反馈