|
| 1 | +# Eslint 使用手册 |
| 2 | + |
| 3 | +代码分析支持 Eslint 分析,并支持用户自由扩展配置。 |
| 4 | + |
| 5 | +## 适用场景 |
| 6 | + |
| 7 | +目前 TCA-Eslint 的适用场景很广,灵活扩展: |
| 8 | + |
| 9 | +- JavaScript |
| 10 | +- TypeScript |
| 11 | +- React |
| 12 | +- Vue |
| 13 | +- Google 代码规范分析 |
| 14 | +- 其他,包括项目自己维护的 Eslint 配置 |
| 15 | + |
| 16 | +## 快速接入 |
| 17 | + |
| 18 | +以下是接入步骤: |
| 19 | + |
| 20 | +1. 在代码分析创建项目,会自动匹配 JavaScript 或者 TypeScript 对应的推荐规则集 |
| 21 | +2. 启动分析即可 |
| 22 | + |
| 23 | +## 高级配置 |
| 24 | + |
| 25 | +### 基础概念 |
| 26 | + |
| 27 | +在进行高级配置之前,这里先普及下代码分析这边的基础概念——Eslint 类型。 |
| 28 | +由于 JavaScript 语法、 Vue 语法和 TypeScript 语法之间的区别,三者使用的语法解析器也是不一样的,这里基于其使用的语法解析器的不同,从 Eslint 中拆分出来了 Eslint_vue 和 Eslint_typescript 工具。可以根据需要选择对应工具下的规则进行分析。而配置也会基于类型的不同匹配到对应的工具中。 |
| 29 | +目前代码分析上 Eslint 类型有: |
| 30 | + |
| 31 | +- JAVASCRIPT |
| 32 | + 分析 JavaScript 以及基于 JavaScript 写的 React 代码,默认分析文件后缀名为.js,.jsx |
| 33 | +- VUE |
| 34 | + 分析 Vue 框架的代码,默认分析文件后缀名为.vue |
| 35 | +- TYPESCRIPT |
| 36 | + 分析 TypeScript 以及基于 TypeScript 写的 React 代码,默认分析文件后缀名为.ts,tsx |
| 37 | + |
| 38 | +### 设置 Globals |
| 39 | + |
| 40 | +因为项目会用到各式各样的框架,其中会有全局变量是 Eslint 无法识别到的,比如 `_` 或者 jtest,从而导致分析出不少误报。这里支持使用下面环境变量设置这些全局变量,减少误报。可以在代码分析项目中设置对应的环境变量。 |
| 41 | + |
| 42 | +| 环境变量名称 | 描述 | |
| 43 | +| :------------------------ | :----------------- | |
| 44 | +| ESLINT_JAVASCRIPT_GLOBALS | 字符串,以分号分割 | |
| 45 | +| ESLINT_VUE_GLOBALS | 字符串,以分号分割 | |
| 46 | +| ESLINT_TYPESCRIPT_GLOBALS | 字符串,以分号分割 | |
| 47 | + |
| 48 | +比如: |
| 49 | + |
| 50 | +```shell |
| 51 | +ESLINT_JAVASCRIPT_GLOBALS=_:readonly;jtest:readonly |
| 52 | +``` |
| 53 | + |
| 54 | +其中, |
| 55 | + |
| 56 | +- writable 表示允许重写变量 |
| 57 | +- readonly 表示不允许重写变量 |
| 58 | +- off 表示禁用该全局变量 |
| 59 | + |
| 60 | +### 指定参数配置文件 |
| 61 | + |
| 62 | +代码分析执行 Eslint 分析,默认会使用 Alloy Team 的 Eslint 配置来分析,但是也支持修改配置。 |
| 63 | + |
| 64 | +1. 在代码库中创建一个参数配置 Json 文件,结果类似 Eslint 的 Json 配置文件 |
| 65 | +2. 在代码分析项目设置下面对应环境变量,指向这个参数配置文件 |
| 66 | + 指定了参数配置文件之后,Eslint 分析时候就会自动将代码分析默认的配置与该参数配置文件进行合并。 |
| 67 | +3. 启动全量分析即可 |
| 68 | + |
| 69 | +| 环境变量名称 | 描述 | |
| 70 | +| :------------------------ | :--------------------------- | |
| 71 | +| ESLINT_JAVASCRIPT_OPTIONS | 字符串,相对代码库根目录路径 | |
| 72 | +| ESLINT_VUE_OPTIONS | 字符串,相对代码库根目录路径 | |
| 73 | +| ESLINT_TYPESCRIPT_OPTIONS | 字符串,相对代码库根目录路径 | |
| 74 | + |
| 75 | +### 指定 Eslint 配置文件 |
| 76 | + |
| 77 | +代码分析也支持用户指定自己维护的 Eslint 配置文件进行分析。 |
| 78 | + |
| 79 | +| 环境变量名称 | 描述 | |
| 80 | +| :----------------------- | :--------------------------- | |
| 81 | +| ESLINT_JAVASCRIPT_CONFIG | 字符串,相对代码库根目录路径 | |
| 82 | +| ESLINT_VUE_CONFIG | 字符串,相对代码库根目录路径 | |
| 83 | +| ESLINT_TYPESCRIPT_CONFIG | 字符串,相对代码库根目录路径 | |
| 84 | + |
| 85 | +### 设置配置类型 |
| 86 | + |
| 87 | +代码分析自带支持 Google 代码规范,可以在代码分析项目设置对应环境变量,使用对应的配置文件。 |
| 88 | + |
| 89 | +| 环境变量名称 | 描述 | |
| 90 | +| :---------------------------- | :---------------------------------------------- | |
| 91 | +| ESLINT_JAVASCRIPT_CONFIG_TYPE | 字符串, google,default,custom | |
| 92 | +| ESLINT_VUE_CONFIG_TYPE | 字符串, 可选:default,custom | |
| 93 | +| ESLINT_TYPESCRIPT_CONFIG_TYPE | 字符串, 可选:default,custom | |
| 94 | + |
| 95 | +其中: |
| 96 | + |
| 97 | +- google,表示使用 google 代码规范配置文件 |
| 98 | +- default,表示使用代码分析维护的配置文件 |
| 99 | +- custom,表示使用项目代码库中 Eslint 配置文件 |
| 100 | + |
| 101 | +### 配置优先顺序 |
| 102 | + |
| 103 | +这里介绍 TCA-Eslint 的配置使用顺序: |
| 104 | + |
| 105 | +1. 优先检查是否设置对应的 ESLINT_CONFIG 环境变量,比如 ESLINT_JAVASCRIPT_CONFIG |
| 106 | +2. 然后检查是否设置对应的 ESLINT_CONFIG_TYPE 环境变量,比如 ESLINT_JAVASCRIPT_CONFIG_TYPE |
| 107 | +3. 若是 JAVASCRIPT 类型的项目,会自动检测代码库根目录下是否有 ESLINT 配置文件,若有则使用该配置文件进行分析,其他类型的项目便不会有这一步 |
| 108 | +4. 使用代码分析维护的 Alloy Team 的配置文件进行分析 |
| 109 | + |
| 110 | +### 分析路径配置 |
| 111 | + |
| 112 | +可以在代码分析页面上设置分析路径设置,这里建议多使用 Exclude 设置,因为 Eslint 工具本身对 include 支持不友好。 |
| 113 | + |
| 114 | +## Q&A |
| 115 | + |
| 116 | +Q:JavaScript 内存溢出 |
| 117 | + |
| 118 | +A:Eslint 执行可能会出现 Js 内存溢出,以下有三种方案可以解决: |
| 119 | + |
| 120 | +- 可以设置环境变量 NODE_OPTIONS,比如 |
| 121 | + |
| 122 | +```shell |
| 123 | +NODE_OPTIONS="--max-old-space-size=4096" |
| 124 | +``` |
| 125 | + |
| 126 | +- 设置环境变量 ESLINT_MAX_OLD_SPACE_SIZE,比如 |
| 127 | + |
| 128 | +```shell |
| 129 | +ESLINT_MAX_OLD_SPACE_SIZE=4096 |
| 130 | +``` |
| 131 | + |
| 132 | +- 设置分析路径过滤,将无用的文件进行过滤 |
| 133 | + |
| 134 | +Q:一个配置同时分析 JS 和 TS |
| 135 | + |
| 136 | +A:若代码库中既有 JavaScript 代码,又有 TypeScript 代码,并且共用一个配置文件。 |
| 137 | +若规则集中既有 Eslint 规则又有 Eslint_typescript 规则,为了避免执行两次 Eslint 以及可能出现重复单的情况,并且因为 Eslint_typescript 的语法解析器也能够解析 JavaScript 代码,所以这里将这样的项目当作 TypeScript 项目。 |
| 138 | + |
| 139 | +1. 这里建议只指定 ESLINT_TYPESCRIPT_CONFIG 环境变量 |
| 140 | +2. 规则集中剔除 Eslint 的规则,只保留 Eslint_typescript 规则。 |
| 141 | +3. 并指定 ESLINT_TYPESCRIPT_EXT=.js,.jsx,.ts,.tsx |
| 142 | + |
| 143 | +Q:找不到依赖 |
| 144 | + |
| 145 | +A:用户自己配置的配置文件中,可能会用到代码分析没有管理到的规则插件,导致分析时候找不到对应的依赖,这里有两个方案提供解决: |
| 146 | + |
| 147 | +- 在代码库根目录下 npm 安装对应插件,并设置分析路径过滤 node_modules |
| 148 | + |
| 149 | +Q:custom 与指定配置文件的区别 |
| 150 | + |
| 151 | +A:- custom 模式,会检测代码库中的 Eslint 配置文件进行分析,包括子目录和代码注释中设置的配置,都是可以生效的。 |
| 152 | + |
| 153 | +- 相对的,指定配置文件的方式,只会对指定的配置文件中的配置会生效。 |
0 commit comments