Skip to content

ESLint

ESLint 官网:https://eslint.org/

ESLint 民间中文网:https://eslint.bootcss.com/

ESLint 的由来

JavaScript 是一个过于灵活的语言,因此在企业开发中,往往会遇到下面两个问题:

  • 如何让所有员工书写高质量的代码?

    比如使用===替代==

  • 如何让所有员工书写的代码风格保持统一?

    比如字符串统一使用单引号

上面两个问题,一个代表着代码的质量,一个代表着代码的风格。

如果纯依靠人工进行检查,不仅费时费力,而且还容易出错。

ESLint 由此诞生,它是一个工具,预先配置好各种规则,通过这些规则来自动化的验证代码,甚至自动修复

image-20211103145844948

ESLint 的基本使用

安装

shell
npm i -D eslint

如何验证

shell
# 验证单个文件
npx eslint 文件名
# 验证全部文件
npx eslint src/**

配置规则

eslint 会自动寻找根目录中的配置文件,它支持三种配置文件:

  • .eslintrc JSON 格式
  • .eslintrc.js JS 格式
  • .eslintrc.yml YAML 格式

这里以.eslintrc.js为例:

js
// ESLint 配置
module.exports = {
  // 配置规则
  rules: {
    规则名1: 级别,
    规则名2: 级别,
    ...
  },
};

每条规则由名称和级别组成

规则名称决定了要检查什么

规则级别决定了检查没通过时的处理方式

所有的规则名称看这里:

所有级别如下:

  • 0 或 'off':关闭规则
  • 1 或 'warn':验证不通过提出警告
  • 2 或 'error':验证不通过报错,退出程序

在 VSCode 中及时发现问题

每次都要输入命令发现问题非常麻烦

可以安装 VSCode 插件ESLint,只要项目的 node_modules 中有 eslint,它就会按照项目根目录下的规则自动检测

使用继承

ESLint 的规则非常庞大,全部自定义过于麻烦

一般我们继承其他企业开源的方案来简化配置

这方面做的比较好的是一家叫 Airbnb 的公司,他们在开发前端项目的时候自定义了一套开源规则,受到全世界的认可

我们只需要安装它即可

shell
# 为了避免版本问题,不要直接安装eslint,直接安装下面的包,会自动安装相应版本的eslint
npm i -D eslint-config-airbnb

然后稍作配置

shell
module.exports = {
	extends: 'airbnb' # 配置继承自 airbnb
}

在框架中使用

一般我们使用脚手架搭建工程,在搭建工程时通常都可以直接设置 eslint

企业开发的实际情况

image-20211103163608481

我们要做什么?

  • 安装好 VSCode 的 ESLint 插件
  • 学会查看 ESLint 错误提示