@cjlumi/eslint-config v1.0.0
order: 1
toc: content
@cjlumi/eslint-config
介绍: 编码 eslint,有多个项目的模板,根据不同项目选择不同配置
提供了多套配置文件以支持 JavaScript、TypeScript、React、等多种项目类型。
1、JavaScript 项目
针对未使用 React 的原生 JavaScript 项目,使用 ESLint 原生规则和 eslint-plugin-import 规则,使用 @babel/eslint-parser 作为 parser,是本包的默认配置。
依赖
安装
npm i -D @cjlumi/eslint-config @babel/core @babel/eslint-parser eslint-plugin-import配置
{
"extends": ["@cjlumi/eslint-config"]
}2、JavaScript + React 项目
针对 JS React 项目,继承了默认配置,并启用了 eslint-plugin-react 和 eslint-plugin-react-hooks 的规则。
依赖
安装
npm i -D @cjlumi/eslint-config @babel/core @babel/eslint-parser eslint-plugin-import eslint-plugin-react eslint-plugin-react-hooks配置
{
"extends": ["@cjlumi/eslint-config/react"]
}3、TypeScript 项目
针对未使用 React 或 Vue 的 TypeScript 项目,继承了默认配置,并启用了 @typescript-eslint/eslint-plugin 插件的规则,使用 @typescript-eslint/parser 作为 parser。
依赖
- @typescript-eslint/parser
- @typescript-eslint/eslint-plugin
- eslint-plugin-import
- eslint-import-resolver-typescript
安装
npm i -D @cjlumi/eslint-config @typescript-eslint/parser @typescript-eslint/eslint-plugin eslint-plugin-import eslint-import-resolver-typescript配置
{
"extends": ["@cjlumi/eslint-config/typescript"]
}需保证项目已安装 typescript 依赖,另外如果项目的 TS 配置文件不是 ./tsconfig.json,则需要设置 .eslintrc 中的 parserOptions.project 字段 ,例如:
{
"extends": "@cjlumi/eslint-config/typescript",
"parserOptions": {
"project": "./tsconfig.eslint.json"
}
}4、TypeScript + React 项目
针对 TS React 项目,继承了 JS React 的配置,并启用了 @typescript-eslint/eslint-plugin 插件的规则,使用 @typescript-eslint/parser 作为 parser。
依赖
- @typescript-eslint/parser
- @typescript-eslint/eslint-plugin
- eslint-plugin-import
- eslint-import-resolver-typescript
- eslint-plugin-react
- eslint-plugin-react-hooks
安装
npm i -D @cjlumi/eslint-config @typescript-eslint/parser @typescript-eslint/eslint-plugin eslint-plugin-import eslint-import-resolver-typescript eslint-plugin-react eslint-plugin-react-hooks配置
{
"extends": ["@cjlumi/eslint-config/typescript/react"]
}5、配合 Prettier 使用
如果你的项目使用 Prettier 进行代码格式化,本包的一些规则可能会跟 Prettier 格式化结果有冲突,例如这条规则。为了避免冲突,你需要手动安装 eslint-config-prettier 和 eslint-plugin-prettier:
安装
npm install --save-dev eslint-config-prettier eslint-plugin-prettier配置
并修改 .eslintrc 的 extends 配置,增加 prettier,如下(以 TS React 项目为例):
{
"extends": ["@cjlumi/eslint-config/typescript/react", "prettier"]
}了解更多请阅读 Prettier - Integrating with Linters。
了解更多
- 如果你对 ESLint 还不熟悉,可以阅读官网的 Getting Started 快速入门。
- 了解如何为 IDE 配置 ESLint,可以参考官网的 Integrations。
- 了解如何在继承本包的基础上对项目 ESLint 进行个性化配置,可参考官网的 Configuring ESLint。下面简介下 ESLint 配置中的几个常用字段:
extends: 继承一组规则集。"extends": "@cjlumi/eslint-config",表示继承本包定义的规则配置。rules: 配置规则,这里定义的规则会覆盖extends的规则。如果觉得本包开启的某条规则过于严格,你可以暂时在这里将其关闭。parser: 设置 ESLint 的解析器。ESLint 使用 espree 作为默认的解析器,可以通过这个参数指定其他的解析器。比如指定为 @babel/eslint-parser,以解析 Babel 支持但 ESLint 默认解析器不支持的语法(本包不同配置文件使用的解析器可在简介表格中的「依赖 parser」一列查看)。globals: 指定代码中可能用到的全局变量,以免全局变量被 no-undef 规则报错。env: 指定代码的运行环境,每个环境预定义了一组对应的全局变量,本包已开启的环境有 browser、node、jquery、es6 及几个测试框架的环境。
- 了解常用的 ESLint 命令,如
--fix、--ext,可参考官网的 Command Line Interface。