在写下这篇文章时,我很庆幸前端只有一套代码质量检查工具 Eslint,因为在“代码格式化规范保持统一”这一件事情上竟然算不上容易去做。
常用编辑器 vscode 和 webstorm,常用工具 eslint 和 prettier。
至于 editorconfig,没有必要去使用,一方面它只会做通用的格式处理,不会分析语法结构;另一方面已经存在 prettier 了,且不如 prettier 好用,没必要再引入增加混乱的局面。
以 vue 项目模版为例,模版代码中定义了 eslint 的配置
extends: [
'plugin:vue/recommended',
'@xm/standard-vue',
],
parserOptions: {
parser: '@babel/eslint-parser'
}
自定义了 @xm/eslint-config-standard-vue
,基于 standard 规范拓展了 2 项:
- comma-dangle(trailing comma) 尾逗号
- space-before-function-paren 函数名称后的空格
这 2 项在很多人的使用规范上有歧义的,所以做了扩展支持。
如果项目未安装,可通过 xnpm 安装后使用
xnpm i @xm/eslint-config-standard-vue -D
封装了统一的 prettier 配置文件,通过 xnpm 安装
xnpm i @xm/prettier-config -D
然后在 package.json 中指明即可
"prettier": "@xm/prettier-config",
由于 webstorm 已足够好用,由于其本身开箱即用,即使新下载的 webstorm,也只需要开启自动 fix 即可:
以 vue 项目为例,官方提供了 vetur 插件用来格式化代码。
4.设置 vue 文件的格式化选项
"[vue]": {
"editor.defaultFormatter": "octref.vetur"
},
"vetur.format.defaultFormatter.html": "js-beautify-html",
"vetur.format.defaultFormatterOptions": {
"js-beautify-html": {
// js-beautify-html settings here
"wrap_attributes": "force"
}
}
6.开启自动保存
"editor.formatOnSave": true,
"files.autoSave": "afterDelay",
"editor.formatOnPaste": true,
"editor.formatOnType": true,
我想用几个疑问来阐述:
- 身为前端开发者我所期望的统一方案是什么?
- 为什么说引入 editorconfig 增加了本就混乱的局面?
- 为什么说 webstorm 足够好用?
第一个问题,在 eslint 足够好用且统一的前提下,编辑器自动保存时,能根据 eslint 的 rules 自动格式化代码,这就是最理想的方案,但是现在 vscode 无法做到。
第二个问题,由于前端技术栈的不稳定性,对于 editorconfig 这种非前端行业的工具来说是不可能为 vue 这样的自定义语法去做扩展的。
prettier 还是前端圈的工具,尚且只想做通用功能。我们可以从很多文档/实例看出,prettier 一直在提供各样的文档和插件用来支撑开发者们搭配 eslint 使用它,这样做是与开箱即用的初衷违背的,但是 eslint 并没有这样做。
为什么要用 prettier?如果你使用的 webstorm 完全没必要使用它。虽然 vue 官方出了 vetur 提供了一些便利性,但是在代码格式化这块,还是不能够让人满意,譬如格式化 template,vetur 给出的方案是 js-beautify
,理想的情况是,代码格式化能严格遵循 eslint-plugin-vue
,现实是 js-beautify-html 并不能够满足。可以看到对于 vscode 的配置,vetur 仅仅只是提供解析 .vue
文件,内部的格式化仍然依赖第三方:
对于 js 的格式化只能使用 prettier,如果你已熟悉 eslint 的规范(standard 或 airbnb),prettier 仅仅只是够用而已,因为他只有通用的功能,没有前端库语法的定制,而 eslint 的 rules 确是通过插件定制的,所以并不好用。
在 prettier 的官网上他们说道,prettier 仅有的几个选项是历史遗留的,其实这几个选项都不应该拥有,应该是开箱即用的,所以对于未来,是不可能新增选项了,参考 **Option Philosophy ,**譬如对于 space-before-function-paren
有人提了个 pr 也被官方义正严辞的给拒绝了:Always add a space after the function
keyword 。
第三个问题,在 vscode 里要格式化 vue 项目代码,既要使用 vetur 又要使用 prettier 还要去看 js-beautify,还得考虑配置项不能和 eslint 的 rules 冲突。
而在 webstorm 中,只需要勾选开关项,即可在保存时格式化为官方定义的 rules 规范。