VSCode怎么进行规范配置?如何格式化代码?下面本篇文章给大家介绍一下各种规范的基本配置,聊聊怎么使用这些配置规范并格式化你的代码,希望对大家有所帮助!
在日常工作中,我们会接触形形色色的工程。如果工程使用的技术架构不同,可能会有对应不同的代码规范。而每个人的编码习惯是不一样的也是难以短时间内改变的,这也是我们常常在开发一个新工程的时候,会遇到各种规范报错的原因。【推荐学习:《vscode教程》】
此时,如果能有一套配置,能够让我们在写代码时不用考虑该工程的规则,只要在保存时就能够自动按照当前工程配置好的规则修复所有错误,这无疑会大大增加我们的开发体验和效率。
下面我将详细讲解为了实现这一目标,我们需要做什么,以及各种规范的基本配置。
EditorConfig
首先,我们需要一个基本的规范,例如缩进,如何换行等等。它要适用于所有的团队,适用于所有的语言,适用于所有的编辑器。
editorconfig
能帮助我们实现这一点。它让所有的开发者在基本编码规范上保持一致。
我们需要做的是:
安装 EditorConfig
插件(有些编辑器默认支持 EditorConfig
,具体请看 这些编辑器不需要安装插件)。
配置 .editorconfig
文件。
以下是 .editorconfig
的用法和例子:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
|
Eslint
对于前端开发工程师来说,JavaScript 无疑是我们最好的伙伴了。而 ESLint,它是一款插件化的 JavaScript 代码静态检查工具,其核心是通过对代码解析得到的 AST(Abstract Syntax Tree,抽象语法树)进行模式匹配,定位不符合约定规范的代码。
社区里有很多不同版本的规范,每个团队也可能会制定自己的规范。编码风格千千万,而工程的配置就一套,在多人协作时就必然会出现规范报错的情况。我们需要配置一套规则,让我们不需要 Care 规则到底是什么,在保存文件的时候,自动按照工程规范格式化代码。
怎么办呢?
Eslint 提供了风格指南规则,并明确表示了哪些是可修复的:Stylistic Issues
我们需要做的是:
本地安装 Eslint 和社区推荐的规范 eslint-config-airbnb (也可以是别的规范)。插件会使用安装的 Eslint 库(如果你还未安装:npm i eslint eslint-config-airbnb
)。
VSCode 安装 Eslint插件
。
添加 .eslintrc.js
配置文件。
更改 VSCode 的 setting.json
文件的配置。
其中,想要实现自动按照工程的规则格式化,第四步必不可少。
setting.json
如果你已经安装好了 Eslint插件
,按 cmd + shif + p
,打开 defaultSettings.json
文件,按 cmd + f
搜索 eslint
可以看到所有 ESlint 在 VSCode 内的默认配置。我们需要对它做一些修改。
还是按 cmd + shift + p
打开 settings.json
文件。这个文件是用户自定义配置,里面的配置会覆盖 defaultSettings.json
里的同名配置。我们在这个文件里对 ESLint插件
的配置做一些修改,让它达到我们想要的效果。
首先,我们想要 保存时自动格式化
,实现这个效果的配置有三种:
editor.formatOnSave
+ eslint.format.enable
。前者配置:保存时格式化
,后者配置:将 ESlint 规则作为格式化标准
。eslint.autoFixOnSave
editor.codeActionsOnSave
其中,第二种 eslint.autoFixOnSave
已经被废弃。使用它会提示更改为 editor.codeActionsOnSave
。
而第一种和第三种都可以实现,但是更推荐使用第三种 editor.codeActionsOnSave
,它支持更高的可配置性。
使用 editor.codeActionsOnSave
的时候,我们需要禁用其它格式化程序,最好的做法是将 ESlint 设置为格式化程序默认值。并且当我们这么做的时候,我们可以关闭 editor.formatOnSave
,否则我们的文件将被修复两次,这是没有必要的。
以下便是我们需要在 setting.json
里新增的配置。(注释的地方是默认配置,无需新增)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
|
.eslintrc.js
接下来,我们聊聊 .eslintrc.js
文件。这个文件将会规定我们的 ESLint 具体该使用什么规则去规范我们的代码。
我们自己往往不需要去配置这个文件,因为工程一般都会配置好了一套规则。我们只需要使用这套规则去格式化代码就好了。
但是看懂每条规则的意义,对于我们也是很重要的,例如你想自己新建工程。
接下来,我将从 普遍用法
、Vue项目特殊配置
、React项目特殊配置
来看下如何配置 .eslintrc.js
文件。
普遍用法
1 2 3 4 5 6 |
|
Node
)我们也希望它能识别,这时候我们可以这样配置:1 2 3 4 5 6 |
|
1 2 3 |
|
1 2 3 4 5 6 7 8 |
|
plugins
关键字来存放插件名字的列表。插件名称可以省略 eslint-plugin-
前缀。1 2 3 |
|
"off"
或 0
- 关闭规则"warn"
或 1
- 开启规则,使用警告级别的错误:warn
(不会导致程序退出)"error"
或 2
- 开启规则,使用错误级别的错误:error
(当被触发的时候,程序会退出)1 2 3 4 5 6 7 |
|
插件名/规则ID
的形式。比如:1 2 3 4 5 6 7 8 9 10 11 |
|
1 2 3 |
|
Vue
特殊配置
由于 Vue
单文件组件的特殊写法,针对 Vue
项目,需要做一些特殊的 ESLint 配置,以达到自动化的效果。
高亮语法支持
安装 Vetur插件
。
使用 ESLint 而不是 Vetur 做代码检测
Vetur 为 Vue
项目带来了语法高亮和便捷的操作。但是它本身也会自动开启对 Vue
文件的代码检测。这往往会和我们配置的 ESLint 有冲突。为了避免这一点,需要在 VSCode 的 settings.json
中做一些配置:
1 2 3 4 5 6 |
|
无需将 vue
添加进 eslint.validate
,因为 eslint.probe
默认会检测 vue
类型文件。
然后,我们需要配置 .eslintrc.js
文件,里面用到的插件都需要本地安装。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
|
以上配置,大家根据自己的项目特点,自行删减即可。比如,如果你的项目不是 nuxt.js
的,可以去掉 extends
里的 '@nuxtjs
和 plugin:nuxt/recommended
。
如果是 Vue cli
创建的项目,并且没有使用 ts
,需要在项目根目录添加 jsconfig.json
文件。有关 jsconfig
的配置在这里:jsconfig
React
特殊配置
React
项目中,因为是 .js
文件,一般不需要特殊的配置。但即使如此,针对 JSX 和 Hooks 的使用规则,我们仍然需要做一些事情
针对 React Hooks
eslint-plugin-hooks
是 React
源码目录 packages
里提供的一个包。它会强制执行 Hooks 规则,它也是 Hooks API 的一部分。
1 |
|
在 .eslintrc.js
中
1 2 3 4 |
|
针对 JSX
JSX 不过只是 React
的一个语法糖,其最终都会被 React 调用 React.createElement 编译城 React Element 形式。所以在 17 版本之前,如果我们使用到了 JSX 但是没有引入 React
,会提示 'React' must be in scope when using JSX
。 而在 17 版本之后, React 与 babel 和 TypeScript 编译器合作,将转化任务交给了编译器自动转化。
如果我们是之前的转化版本,我们要获得对 JSX 的语法支持,我们需要安装 eslint-plugin-react
,它内置了对 JSX 的代码规范检测。
1 2 3 |
|
如果不想使用内置的规则,我们也可以自定义规则
1 2 3 4 5 6 7 8 9 10 11 |
|
如果是新的转化版本,则需要做一点小小的更改,以便在使用 JSX 的时候,不会要求我们引入 React
。
1 2 3 |
|
StyleLint
在完成了以上的配置之后,我们已经可以对 .js
文件、.vue
文件的 template
和 script
模块实现代码规范和保存时自动格式化了。但是对于 .css、.less、.scss
文件和 .vue
文件的 style
模块,我们还需要做额外的配置,否则样式部分不规范,我们也是没法检测并自动修复的。
我们需要做的是:
npm i stylelint stylelint-config-standard stylelint-scss
。
安装 Stylelint插件
。
配置 .stylelintrc
文件。
配置 VSCode 的 setting.json
文件。
其中,第四步也是必须的,我们需要做如下配置:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
|
以上,我们的目标已经达成啦!
Prettier
代码格式化工具。很多同学都接触过这个工具,我个人深入了解了一下这个工具,以下是我的个人见解。先看下 Prettier 官方的一段话吧。
So why choose the “Prettier style guide” over any other random style guide? Because Prettier is the only “style guide” that is fully automatic. Even if Prettier does not format all code 100% the way you’d like, it’s worth the “sacrifice” given the unique benefits of Prettier, don’t you think?
可以看到,这个工具旨在让不同公司不同团队不需要考虑代码规范,实现自动化保存格式化。牺牲掉个性化内容。
但是往往不同的团队对规则的使用是不一致的,如果强制所有文件都使用 prettier
自动格式化,会出现与公司配置的代码规范检查工具(例如 ESLint) 冲突的情况。实际表现为自动保存之后,依然出现 ESLint 格式报错。
想让 prettier
生效,需要我们在 VSCode 里配置:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
可以使用 .prettierrc
文件、VSCode 的 setting.json
、.editorConfig
来配置 prettier
。
推荐不常使用的文件类型,使用 prettier
去格式化。js,json,jsx,html,css,less,vue
等这些文件,使用工程统一的规范去格式化。
所以,我觉得完全可以卸载它。不知道你怎么看呢?
以上就是全部内容了,希望对你有所帮助~
更多编程相关知识,请访问:编程入门!!
以上是VSCode怎么进行规范配置?如何格式化代码?的详细内容。更多信息请关注PHP中文网其他相关文章!