懒人攻略(快速上手使用总结)
没有时间深入了解?6步快速带你配置团队代码规范,抄作业还不快乐吗!
- 分别安装VSCode插件:
Prettier
、ESLint
、EditorConfig
; 拉取最新代码,执行
npm install
,自动本地下载eslint
、eslint-config-prettier
、babel-eslint
、prettier
、eslint-config-prettier
等依赖;npm install eslint eslint-config-prettier babel-eslint prettier eslint-config-prettier --save-dev
- 按需添加
.prettierrc
、.stylelintrc
、.editorconfig
等配置文件来规范团队代码,具体配置可酌情参考文末推荐配置。 - 安装 Pre-commit Hook:
npx mrm lint-staged
- 执行
git commit
后 ESLint 会进行格式检查并自动修复,对于不能自动修复的语法会进行警告并阻止 commit; 在package.json中添加命令,使用
npm run lint
检查语法和格式,使用npm run lint —fix
对语法和格式进行修复"scripts": { "lint": "eslint --ext .js,.vue src", "lint-fix": "eslint --fix --ext .js,.vue src/" },
全文结束!(手动滑稽.png)
ESLint
ESLint 是什么
是一个开源的 JavaScript 的 linting 工具,使用 espree 将 JavaScript 代码解析成抽象语法树 (AST),然后通过AST 来分析我们代码,从而给予我们两种提示:
- 代码质量问题:使用方式有可能有问题(problematic patterns)
- 代码风格问题:风格不符合一定规则 (doesn’t adhere to certain style guidelines)
官方文档:ESLint - 插件化的 JavaScript 代码检测工具 - ESLint中文文档
先决条件
- Node.js (>=6.14);
- npm version 3+。
使用
安装 ESLint
npm install eslint —save-dev
安装 babel-eslint
npm install babel-eslint --save-dev
安装 eslint-config-prettier
npm install eslint-config-prettier --save-dev
初始化 ESLint 配置文件
使用 eslint --init
开始创建一个 ESLint 配置文件
错误等级
- “off” or 0 - 关闭规则
- “warn” or 1 - 将规则视为一个警告(不会影响退出码)
- “error” or 2 - 将规则视为一个错误 (退出码为1)
官方推荐规则
- 使用
"extends": "eslint:recommended"
来开启推荐规则,详见List of available rules - ESLint中文文档
配置说明
- Environments - 指定脚本的运行环境。每种环境都有一组特定的预定义全局变量。
- Globals - 脚本在执行期间访问的额外的全局变量。
- Rules - 启用的规则及其各自的错误级别。
- plugins - 第三方插件
- Extends - 继承
- Parser - 解析器,ESLint 默认使用 Espree 作为其解析器。
- parserOptions — 常用于设置语法解析器的一些配置。
忽略ESLint
新增 .eslintignore 文件,你可以通过在项目根目录创建一个 .eslintignore 文件告诉 ESLint 去忽略特定的文件和目录
.eslintignore 文件是一个纯文本文件,其中的每一行都是一个 glob 模式表明哪些路径应该忽略检测。例如,以下将忽略所有的 JavaScript 文件:
**/*.js
文件中取消 ESLint 常用注释
/* eslint-disable */ —- 禁用全部规则 放在文件顶部则整个文件范围都不检查
/* eslint-disable no-alert, no-console */ -— 禁用某些规则
// eslint-disable-line -— 当前行上禁用规则
// eslint-disable-next-line —- 下一行上禁用规则
常用命令行
查看所有命令行选项:eslint -h
自动修复问题:eslint —-fix
禁用使用.eslintrc中的配置:eslint -—no-eslintrc
对单个文件或文件目录进行格式化:eslint [options] [file|dir|glob]*
使用指定目录中的其他规则:eslant —-rulesdir [path::String]
只报告错误,默认false:eslint —-quiet
只检查有改动的文件,默认false:eslint -—cache
明确格式化报告的输出文件:eslint -o, —output-file path::String
Prettier
Prettier 是什么
官方文档:Prettier
上面我们说到,ESLint 主要解决了两类问题,但其实 ESLint 主要解决的是代码质量问题。另外一类代码风格问题其实 ESLint 并没有完全做完,因为这些问题”没那么重要”,代码质量出问题意味着程序有潜在 Bug,而风格问题充其量也只是看着不爽。
这时候就出现了 Prettier,Prettier 声称自己是一个有主见 (偏见) 的代码格式化工具 (opinionated code formatter),Prettier 认为格式很重要,所以相当于 Prettier 接管了两个问题其中的代码格式的问题,而使用 Prettier + ESLint 就完全解决了两个问题。
使用
安装 prettier
npm install —save-dev —save-exact prettier
安装 eslint-config-prettier
npm install —save-dev eslint-config-prettier
安装 lint-staged
npx mrm lint-staged
忽略 Prettier
使用.prettierignore
文件完全忽略(即不重新格式化)某些文件和文件夹。
# Ignore artifacts:
build
coverage
# Ignore all HTML files:
*.html
总结
- 在你的编辑器中安装正确版本的 Prettier 插件,确保团队中每个人安装的版本是一致的;
- 在项目中本地安装正确版本的 Prettier 依赖,确保团队中每个人安装的版本是一致的;
- 添加一个
.prettierrc.json
配置文件去告诉编辑器你正在使用 Prettier; - 添加一个
.prettierignore
配置文件告诉你的编辑器哪些文件不需要格式化; - 通过运行
npx prettier —write .
去格式化整个项目的文件; - 通过运行
npx prettier —check .
检查每个项目文件的格式规范; - 使用 eslint-config-prettier 确保 ESLint 和 Prettier 能够完美协作;
- 设置 pre-commit 钩子确保每一次提交的代码都是经过格式化的。
EditorConfig
EditorConfig 是什么
官方文档:EditorConfig
主要用于维护多个编辑器和 IDE 从事同一项目的多个开发人员的一致编码风格。EditorConfig 项目包括一个用于定义编码样式的文件格式和一个文本编辑器插件集合,这些文本编辑器插件使编辑器可以读取文件格式并遵循定义的样式。
EditorConfig 和 ESLint 侧重点不同,EditorConfig 更偏向于代码风格,定义和维护一致的编码风格。ESLint 侧重于检查 Javascript 编程语法错误,二者并不冲突,同时配合使用可以使代码风格更加优雅。
推荐配置
editorConfig配置:.editorConfig文件
# EditorConfig is awesome: https://EditorConfig.org
# top-most EditorConfig file
# 适用范围:跨编辑器和IDE编写代码,保持一致的简单编码风格
# special property that should be specified at the top of the file outside of any sections. Set to true to stop .editorconfig files search on current file.
root = true
# Unix-style newlines with a newline ending every file
[*]
end_of_line = lf # set to lf, cr, or crlf to control how line breaks are represented.
insert_final_newline = true # set to true to ensure file ends with a newline when saving and false to ensure it doesn't.
# Indentation override for all JS under lib directory
[**.{js,vue,ts}]
charset = utf-8 # set to latin1, utf-8, utf-8-bom, utf-16be or utf-16le to control the character set.
indent_style = space # set to tab or space to use hard tabs or soft tabs respectively.
indent_size = 4 # use 4 spaces instead of tabs;
trim_trailing_whitespace = true # remove trailing white space characters when saving
[*.md]
trim_trailing_whitespace = false
# Matches the exact files either package.json or .travis.yml
[{package.json,.travis.yml}]
indent_style = space
indent_size = 4
Prettier配置 :.prettierrc文件
{
"singleQuote": true,
"semi": true,
"arrowParens": "avoid",
"bracketSpacing": true,
"embeddedLanguageFormatting": "auto",
"htmlWhitespaceSensitivity": "css",
"insertPragma": false,
"jsxBracketSameLine": false,
"jsxSingleQuote": false,
"printWidth": 200,
"proseWrap": "never",
"quoteProps": "as-needed",
"requirePragma": false,
"tabWidth": 4,
"trailingComma": "none",
"useTabs": false,
"vueIndentScriptAndStyle": false
}
ESLint配置: .eslintrc.js文件
module.exports = {
env: {
es6: true,
browser: true,
node: true,
commonjs: true,
amd: true
},
extends: ['eslint:recommended', 'plugin:vue/essential', 'plugin:prettier/recommended'],
parserOptions: {
ecmaVersion: 12,
sourceType: 'module',
parser: 'babel-eslint'
},
plugins: ['vue', 'prettier'],
rules: {
'prettier/prettier': 'error',
indent: ['error', 4],
'linebreak-style': ['error', 'unix'],
quotes: ['error', 'single'],
semi: ['error', 'always']
}
};
VSCode 编辑器拓展插件
- Vetur - Visual Studio Marketplace
- ESLint - Visual Studio Marketplace
- EditorConfig for VS Code - Visual Studio Marketplace