# encode-f2elint
encode-f2elint 是bell 前端编码规范工程化 (opens new window)的配套 Lint 工具,可以为项目一键接入规范、一键扫描和修复规范问题,保障项目的编码规范和代码质量。
# 背景
我们引入了多个业界流行的 Linter,并根据规范内容定制了规则包,它们包括:
| 规范 | Lint 工具 | npm 包 |
|---|---|---|
| JavaScript 编码规范 TypeScript 编码规范 Node 编码规范 | ESLint (opens new window) | eslint-config-bell (opens new window) |
| CSS 编码规范 | stylelint (opens new window) | stylelint-config-bell (opens new window) |
| Git 规范 | commitlint (opens new window) | commitlint-config-bell (opens new window) |
| 文档规范 | markdownlint (opens new window) | markdownlint-config-bell (opens new window) |
可以看到这些 Linter 和规则包众多且零散,全部安装它们会给项目增加十几个依赖,接入和升级成本都比较高。
encode-f2elint 收敛屏蔽了这些依赖和配置细节,提供简单的 CLI 和 Node.js API,让项目能够一键接入、一键扫描、一键修复、一键升级,并为项目配置 git commit 卡口,降低项目接入规范的成本。
# CLI 使用
# 安装
在终端执行:
npm install encode-f2elint -g
安装完成后,可执行 encode-f2elint -h 以验证安装成功。
# 使用
# encode-f2elint init:一键接入
在项目根目录执行 encode-f2elint init,即可一键接入规范,为项目安装规范 Lint 所需的依赖和配置。
具体会做以下事情:
- 安装各种依赖:包括
Linter依赖,如 ESLint (opens new window)、stylelint (opens new window)、commitlint (opens new window)、markdownlint (opens new window) 等;配置依赖,如 eslint-config-bell (opens new window)、stylelint-config-bell (opens new window)、commitlint-config-bell (opens new window)、markdownlint-config-bell (opens new window) 等 - 写入各种配置文件,包括:
.eslintrc.js、.eslintignore:ESLint 配置(继承eslint-config-bell)及黑名单文件.stylelintrc.js、.stylelintignore:stylelint 配置(继承stylelint-config-bell)及黑名单文件commitlint.config.js:commitlint 配置(继承commitlint-config-bell).markdownlint.json、.markdownlintignore:markdownlint配置及黑名单文件.prettierrc.js:符合规范的 Prettier 配置 (opens new window).editorconfig:符合规范的 editorconfig (opens new window).vscode/extensions.json:写入规范相关的 VSCode 插件推荐 (opens new window),包括ESLint、stylelint、markdownlint、prettier等.vscode/settings.json:写入规范相关的 VSCode 设置 (opens new window),设置ESLint和stylelint插件的validate及保存时自动运行 fix,如果选择使用Prettier,会同时将prettier-vscode插件设置为各前端语言的 defaultFormatter,并配置保存时自动格式化encode-f2elint.config.jsencode-f2elint 包的一些配置,如启用的功能等
- 配置 git commit 卡口:使用 husky (opens new window) 设置代码提交卡口,在 git commit 时会运行
encode-f2elint commit-file-scan和encode-f2elint commit-msg-scan分别对提交文件和提交信息进行规范检查。encode-f2elint commit-file-scan默认仅对 error 问题卡口,如果你想对 warn 问题也卡口,可以增加--strict参数以开启严格模式
注 1:如果项目已经配置过 ESLint、stylelint 等 Linter,执行
encode-f2elint init将会提示存在冲突的依赖和配置,并在得到确认后进行覆盖:注 2:如果项目的 .vscode/ 目录被 .gitignore 忽略,可以在拉取项目后单独执行
encode-f2elint init --vscode命令写入.vscode/extensions.json和.vscode/settings.json配置文件
# encode-f2elint scan:一键扫描
在项目的根目录执行命令,即可扫描项目的规范问题:
支持下列参数:
-q--quiet仅报告 error 级别的问题-o--output-report输出扫描出的规范问题日志-i--include <dirpath>指定要进行规范扫描的目录--no-ignore忽略 eslint 的 ignore 配置文件和 ignore 规则
注 1:事实上,你可以在任意目录执行
encode-f2elint scanencode-f2elint会根据文件类型、JSON 等特征嗅探项目类型。但我们还是推荐在执行过encode-f2elint init的项目根目录执行encode-f2elint scan,以得到最准确的扫描结果。注 2:
encode-f2elint会根据项目内有无 eslint 和 stylelint 配置文件判断使用项目的配置文件还是encode-f2elint默认配置进行扫描。若使用项目的,在未安装依赖时会帮其安装(执行 npm i)。若使用项目配置扫描失败,则使用默认配置扫描
# encode-f2elint fix:一键修复
在项目的根目录执行命令,即可修复部分规范问题:
支持下列参数:
-i--include <dirpath>指定要进行修复扫描的目录--no-ignore忽略 eslint 的 ignore 配置文件和 ignore 规则
注意请 review 下修复前后的代码,以免工具误修的情况。
# encode-f2elint commit-file-scan 提交文件扫描
在 git commit 时对提交文件进行规范问题扫描,需配合 git 的 pre-commit 钩子使用。
支持下列参数:
-s--strict严格模式,对 warn 和 error 问题都卡口,默认仅对 error 问题卡口
# encode-f2elint commit-msg-scan 提交信息扫描
git commit 时对 commit message 的格式进行扫描(使用 commitlint),需配合 husky (opens new window) 的 commit-msg 钩子使用。
# Node.js API 使用
# 安装
npm install encode-f2elint --save
# API
# init:初始化
- encode-f2elint.init(config):将项目一键接入规范,效果等同于
encode-f2elint init
示例:
(await encode) -
fe -
lint.init({
eslintType: 'react',
enableESLint: true,
enableStylelint: true,
enableMarkdownlint: true,
enablePrettier: true,
disableNpmInstall: false,
});
config 参数如下:
| 参数 | 类型 | 默认值 | 说明 |
|---|---|---|---|
| cwd | string | - | 项目绝对路径 |
| eslintType | ESLintType | - | 语言和框架类型,如果不配置,等同于 encode-f2elint init,控制台会出现选择器,如果配置,控制台就不会出现选择器 |
| enableESLint | boolean | true | 是否启用 ESLint,如果不配置默认值为 true,即默认启用 ESLint |
| enableStylelint | boolean | - | 是否启用 stylelint,如果不配置,等同于 encode-f2elint init,控制台会出现选择器,如果配置,控制台就不会出现选择器 |
| enableMarkdownlint | boolean | - | 是否启用 markdownlint,如果不配置,等同于 encode-f2elint init,控制台会出现选择器,如果配置,控制台就不会出现选择器 |
| enablePrettier | boolean | - | 是否启用 Prettier |
| disableNpmInstall | boolean | false | 是否禁用自动在初始化完成后安装依赖 |
# ESLintType
default: JavaScript 项目(未使用 React 和 Vue 的 JS 项目)react: JavaScript + React 项目vue: JavaScript + Vue 项目typescript/default: TypeScript 项目(未使用 React 和 Vue 的 TS 项目)typescript/react: TypeScript + React 项目typescript/vue: TypeScript + Vue 项目es5: ES5 及之前版本的 JavaScript 老项目
# 配置
encode-f2elint 基于一份配置进行扫描(但你也可以零配置使用),支持的配置参数有:
| 参数 | 类型 | 默认值 | 说明 |
|---|---|---|---|
| enableESLint | boolean | true | 是否启用 ESLint |
| enableStylelint | boolean | true | 是否启用 stylelint |
| enableMarkdownlint | boolean | true | 是否启用 markdownlint |
| enablePrettier | boolean | - | 是否启用 Prettier |
| eslintOptions | ESLint.Options | - | ESLint 配置项,若未设置将使用执行目录下或内置的默认 eslintrc 和 eslintignore 进行扫描 |
| stylelintOptions | stylelint.LinterOptions | - | stylelint 配置项,若未设置将使用执行目录下或内置的默认 stylelintrc 和 stylelintignore 进行扫描 |
| markdownlintOptions | markdownlint.Options | - | markdownlint 配置项,若未设置将使用执行目录下或内置的默认 markdownlint 配置文件进行扫描 |
encode-f2elint 会读取执行目录下的 encode-f2elint.config.js 作为配置文件。encode-f2elint init 会在执行目录下新增如下的 encode-f2elint.config.js 文件:
module.exports = {
enableESLint: true,
enableStylelint: true,
enableMarkdownlint: true,
enablePrettier: true,
};
# 常见问题
# TypeScript 项目扫描性能问题
如果你的 TS 项目 commit 卡口和 encode-f2elint scan 运行时间很长,可以通过如下在 .eslintrc.js 中增加以下配置提升性能:
module.exports = {
parserOptions: {
project: [], // for lint performance
createDefaultProgram: false, // for lint performance
},
rules: {
'@typescript-eslint/dot-notation': 0, // for lint performance
'@typescript-eslint/restrict-plus-operands': 0, // for lint performance
},
};