聊聊ESLint与Prettier在vscode中怎么进行代码自动格式化

聊聊ESLint与Prettier在vscode中怎么进行代码自动格式化

前端代码格式化社区提供了两种比较常用的工具ESLintPrettier,他们分别提供了对应的vscode的插件,二者在代码格式化方面有重叠的部分,规则不一致时会导致冲突。vscode作为前端开发编辑器已经越来越普遍了,这需要开发者在vscode对他们的使用有一定的了解,掌握其中的原理对提升开发效率保证代码质量方面会有很大的帮助,俗话中的工欲善其事必先利其器磨刀不误砍柴工都是类似的道理。【推荐学习:vscode教程、编程视频】

ESLint介绍

ESLint的作用

ESLint的具体的用法以及原理等不在本文的介绍范围,可自行查询资料。

ESLint的作用应该大家都知道,它是一个检查代码质量与风格的工具,配置一套规则,就能检查出你代码中不符合规则的地方,部分问题支持自动修复;总结起来就两个功能:

代码质量检查

可以发现代码中存在的可能错误,如使用未声明变量声明而未使用的变量修改 const 变量代码中使用debugger等等

代码格式化

可以用来统一团队的代码风格,比如加不加分号使用 tab 还是空格字符串使用单引号 等等

如何在vscode中启用ESLint

vscode使用ESLint进行代码检查的条件:

首先,需要在vscode中安装ESLint插件并启用,同时需要在vscode配置中开启eslint的检查。

具体开启在用户级别的setting或者项目级别的settings.json中进行如下设置:

{    "eslint.enable": true, // 开启eslint检查 }

其次,需要在当前项目根目录或者全局安装eslint,另外eslint的规则配置项中的依赖也需要安装。

若没有安装,则在vsconde的eslint控制台输出如下错误:

1.png

最后,需要在项目根目录有配置文件.eslintrc.js或者.eslintrc.json,或者在根项目的package.json中配置项eslintConfig中配置eslint的规则。

若没有任何配置文件,则eslint控制台会输出如下错误:

2.png

上面三个步骤缺一不可,都配置完后我们在vscode编辑中就能看到代码被eslint检查的结果,js代码结果类似如下图所示:

3.png

eslint根据设置值的规则检查两个问题:红色波浪线提示变量定义但未使用;黄色波浪线提示字符串必须使用单引号。对于这些错误,vscode编辑器将eslint的检查结果仅展示给开发者。

其实,vscode可以用eslint在文件保存时对部分的问题代码进行自动修复,如上图中的黄色波浪线部分,这需要在vscode配置eslint进行文件保存时自动格式化代码,具体是通过vscode的codeActionsOnSave.source.fixAll来设置,详情如下:

{    "eslint.enable": true, // 开启eslint检查    "editor.codeActionsOnSave": {        // 使用eslint来fix,包括格式化会自动fix和代码质量检查会给出错误提示        "source.fixAll.eslint": true      }}

修改后再次保存代码,部分不符合规则的代码自动格式化了,如下图所示:

4.png

顺便提示下:

若设置codeActionsOnSave.source.fixAll: true,表示使用所有提供的代码格式工具进行代码格式化,包括eslint,猛戳这里

Prettier介绍

Prettier的作用

Prettier的作用是对代码进行格式化,并不关注代码质量潜在问题的检查。

Prettier 自身的规范倾向于团队的代码风格的规范或统一,例如每行最大长度,单引号还是双引号,等号左右空格,使用tab还是空格等等。

除了js/ts外,它还支持对多种语言进行格式化,如vue、html、css、less、scss、json、jsx等等,是一个比较综合的代码格式化工具。

有了ESLint为啥还要用Prettier

介绍ESLint时说到它也有代码格式化的功能,为啥还需要用Prettier,引用这篇文章介绍了几个点:

ESLint 安装和配置比较麻烦,而且 lint 的速度并不快Prettier 并不只针对 JavaScript,它可以格式化各种流行语言Prettier 的配置选项没那么眼花缭乱,比 ESLint 少很多,这在Prettier选项的哲学中说明精简的原因。

如何在vscode启用Prettier

vscode中启用Prettier相对来说比较简单,并不需要在当前项目中安装Prettier,只需:

在vscode中安装Prettier插件并启用,同时需要设置Prettier为对应的代码默认格式化,或者将其设置为指定语言的代码格式化。

在用户级别的settings.json中设置编辑器的默认代码格式化器:

{   "editor.defaultFormatter": "esbenp.prettier-vscode"}

或者为指定语音设置默认格式化器:

{   "[javascript]" {       "editor.defaultFormatter": "esbenp.prettier-vscode"   }}

上面虽然在vscode启用了Prettier,但是并没有在保存文件时进行代码格式化,要想实现自动保存代码进行代码格式化,需要:

vscode开启代码保存时进行格式化将Prettier作为默认的格式化工具,或者将Prettier设置为指定语言的格式化器是否设置需要Prettier的配置文件(.prettierrc.editorconfig),有两种情况:

若配置"prettier.requireConfig": true则要求根目录下有Prettier的配置文件,它会覆盖Prettier扩展中的默认配置,如下图所示;否则保存时不会自动格式化。可以参考这里。

5.png

若配置"prettier.requireConfig": false则不要求根目录下有配置文件,若有的话也会被感知到并以配置文件的内容为准,如下图是没有配置文件时的提示信息:

6.png

上面三个步骤的在vscode中的配置体现如下:

{  "editor.formatOnSave": true, // 开启保存文件自动格式化代码  "editor.defaultFormatter": "esbenp.prettier-vscode", // 默认的代码格式化工具  "prettier.requireConfig": true // 需要Prettier的配置文件}

再啰嗦一句:若设置需要配置文件,则必须要求根目录下有配置文件.prettierrc.editorconfig中的一个或者两个同时存在,否则代码保存不会进行格式化。

可能你会对上面.editorconfig文件作为Prettier的配置文件感到疑惑,vscode的Prettier插件中有关配置文件有这样的一段描述,如下图:

7.png

可以看出Prettier插件获取配置文件有一个优先级:.prettierrc > .editorconfig > vscode默认配置

上面的前两者并不是说.prettierrc.editorconfig同时存在时,后者的配置内容就被忽略,实际的表现:

.prettierrc.editorconfig同时存在时,二者内容会进行合并,若配置项有冲突,这.prettierrc的优先级更高。

ESLint与Prettier的冲突

冲突的原因

ESLintPrettier都可以进行代码格式化方面,若二者同时出现下面的情况就会出现冲突:

重叠的格式化规则不一致,二者重叠的配置规则可以参考这里。vscode同时开启二者进行格式化

{    "editor.formatOnSave": true,    "editor.defaultFormatter": "esbenp.prettier-vscode",    "prettier.requireConfig": true,    "eslint.enable": true, // eslint开启    "editor.codeActionsOnSave": {       "source.fixAll.eslint": true // 代码保存使用eslint格式化     }}

满足上面的条件就会出现冲突,借鉴这篇文章的一幅图来展示:

8.png

例如当前的项目中ESLint使用array-bracket-newline配置数组项不需要换行,而Prettier对其默认是按换行进行格式化,那么该规则就出现冲突,在文件保存时代其表现下图:

9.gif

可以看出文件保存后代码格式化时会出现闪缩的效果,这是因为二者都对代码进行了格式化,但是最终结果取决是谁最后一个进行格式化,从上图结果来看是Prettier是最后执行,它的格式化的结果为最终输出结果,原因:

Prettier的格式化耗时  > ESLint的格式化耗时

最终以Prettier的格式化结果来输出,但是这就与ESLint的规则冲突,vscode编辑器就会将ESLint结果给展示出来。

以和为贵:ESLint与Prettier和谐共处

鉴于Prettier在代码格式化方面的优劣:

优势:可以对多种语言进行代码格式化,不仅仅是javascript劣势:不具备代码质量检查的能力

所以最佳方案是整合二者,取各方之长。但上一节分析了两者同时存在时冲突的原因,那么在二者共存的情况下解决思路就比较明确了,有两种方案:

二者重叠的格式化规则保持一致二者共同作用的语言使用其中一种进行格式化

下面分别对这两种方案进行介绍。

二者重叠的格式化规则保持一致

前面提到,二者之所以出现冲突的条件之一是同时在vscode中开启:

{    "editor.formatOnSave": true,    "editor.defaultFormatter": "esbenp.prettier-vscode",    "prettier.requireConfig": true,    "eslint.enable": true,    "editor.codeActionsOnSave": {       "source.fixAll.eslint": true     }}

那么要搞清楚二者重叠的规则有哪些?重叠的规则有哪些是冲突的呢?好在社区有了答案可以参考这里,针对这种情况也给出了比较好的解决方案,具体来说:

在使用ESLint作为代码的格式化工具时,关闭可能与Prettier有冲突的格式化规则,把Prettier当做一个linter规则。

主要是使用下面两个包:

eslint-config-prettier 会关闭ESLint中有关代码格式化的配置,具体参考这里。

eslint-plugin-prettierPrettier配置成ESLint的一个插件,让其当做一个linter规则来运行,可参考其编程视频2。

注意:eslint-plugin-prettier需要项目安装Prettier依赖

这样,只需在项目根目录下的.eslintrc.js中配置如下:

{  "extends": ["plugin:prettier/recommended"]}

plugin:prettier/recommended帮我们做了如下事情:

{  "extends": ["prettier"], // 使用eslinst-config-prettier中的配置项  "plugins": ["prettier"], // 注册该prettier插件  "rules": {    "prettier/prettier": "error", // 在eslint中运行prettier,并启用该插件提供的规则    "arrow-body-style": "off", // 关闭规则    "prefer-arrow-callback": "off" // 关闭规则  }}

这样配置后,ESLint进行格式化时就会忽略跟Prettier重叠的格式规则,这些交由Prettier来进行格式化,这样二者可以愉快地一起分工协作了。

二者共同作用的语言使用其中一种进行格式化

方案一让二者协同工作的思路在ESLint中关闭跟Prettier可能存在冲突的规则,但是并没有避免二者同时格式化,也就是说实际上二者都参与了代码的格式化,只是输出内容一致而已

可以从vscode的用户settings.json配置文件可以看出:

"editor.formatOnSave": true"editor.defaultFormatter": "esbenp.prettier-vscode"配置,告诉vscode在文件保存时都使用默认的Prettier来对代码格式化。

editor.codeActionsOnSave.source.fixAll.eslint: true设置代码保存时使用ESLint来进行格式化。

因为方案一本质上执行了两次代码格式化,所以我们可以有另一种思考:只使用二者中的一个进行代码格式化。

我们知道,ESLint只对javascript、typescript以及javascrpitreact进行代码格式化,而对其他语言则无效,而Prettier是可以的,所以针对二者共同作用的语言,我们可以关闭文件保存时自动格式化,也就是关闭Prettier作为代码格式化工具,如下配置:

{    "editor.formatOnSave": true,     "editor.defaultFormatter": "esbenp.prettier-vscode",    //针对共用的语言如JS、TS和JSX关闭文件保存自动格式化功能,通过eslint来做这件事     "[javascript]": {         "editor.formatOnSave": false     },     "[javascriptreact]": {        "editor.formatOnSave": false    },    "[typescript]": {        "editor.formatOnSave": false    },    "editor.codeActionsOnSave": { //告诉ESLint插件在保存时运行         "source.fixAll.eslint": true     }}

这样,在js、ts或者jsx的文件保存时,不会调用Prettier进行格式化,而是交由ESLint来完成,除此之前的语言则是使用Prettier来进行代码格式化。

补充:editor.formatOnSave vs editor.codeActionsOnSave

ESLintPrettier存在冲突的一个原因,也在于vscode对文件保存时的配置操作有重合的地方,体现在formatOnSavecodeActionsOnSave上,二者都可以实现文件保存时格式代码,有重合的地方,对称有人在vscode社区提出是否可以删除一个:编程视频3。

vscode并没有采纳删除或者合并的建议,其提供这两个的配置,其出发点是不一样的,下面是社区的一段描述:

But the main difference between codeActionsOnSave and formatOnSave remains that:

the latter (formatOnSave) only formats code,while the former (codeActionsOnSave) can run one or several commands on the code, commands which might not be related to formatting.

The following editor.codeActionsOnSave will always run Organize Imports followed by Fix All once organize imports finishes:

"editor.codeActionsOnSave": [    "source.organizeImports",    "source.fixAll"]

更多关于VSCode的相关知识,请访问:编程视频4!

以上就是聊聊ESLint与Prettier在vscode中怎么进行代码自动格式化的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/56401.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月10日 00:52:25
下一篇 2025年11月10日 00:56:33

相关推荐

  • 使用Windows调试Go (Golang) 代码

    本文旨在提供在Windows%ignore_a_1%下调试Go (Golang) 代码的有效方法。由于GDB在Windows上的局限性,本文将探讨替代方案,包括使用集成开发环境(IDE)以及其他调试工具,帮助开发者更高效地定位和解决Go程序中的问题。 在Windows环境下调试Go代码,开发者可能会…

    2025年12月16日
    000
  • Golang如何在IDE中配置调试环境

    安装Delve调试器并配置IDE是Golang调试的核心。首先通过go install github.com/go-delve/delve/cmd/dlv@latest安装Delve,运行dlv version验证安装;若命令未找到,需将GOBIN(通常为$GOPATH/bin)加入系统PATH。在…

    2025年12月16日
    000
  • Golang调试工具安装与配置示例

    Delve是Go语言专用调试工具,支持断点、变量查看和堆栈追踪。通过go install安装后,可用dlv version验证;在VS Code中配置launch.json可实现图形化调试;命令行下使用break、continue、locals等命令进行调试操作;注意权限、路径及模块模式问题。 Go…

    2025年12月16日
    000
  • Golang插件管理与代码提示优化实践

    答案:合理配置Go语言服务器gopls与编辑器插件可显著提升开发效率。建议使用VS Code配合最新Go扩展,启用gopls并关闭旧工具;配置completeUnimported、usePlaceholders等提升补全体验;通过GOPROXY加速模块下载;在多模块项目中使用gopls.work文件…

    2025年12月16日
    000
  • Golang如何在IDE中调试远程程序

    使用Delve可在IDE中实现Go远程调试。先在服务器安装Delve并以headless模式启动,监听指定端口;再在GoLand或VS Code中配置远程连接,确保源码路径一致;通过SSH隧道可提升安全性,最终实现如本地般断点调试。 在Go语言开发中,调试远程程序是常见的需求,尤其是在生产环境或容器…

    好文分享 2025年12月16日
    000
  • Golang Docker容器环境搭建与开发示例

    首先搭建Go与Docker环境,再编写Web服务并创建Dockerfile,最后构建镜像运行容器实现应用容器化。 在现代后端开发中,Go语言(Golang)与Docker的结合越来越普遍。这种组合不仅能提升开发效率,还能保证应用在不同环境中的稳定性。本文将带你一步步搭建Golang的Docker开发…

    2025年12月16日
    000
  • Golang VSCode开发环境插件配置与优化

    答案:配置VSCode的Go开发环境需安装Go插件、gopls和Delve,启用保存格式化与代码诊断,配置launch.json实现高效编码与调试。 使用 VSCode 搭建高效的 Golang 开发环境,关键在于合理配置插件与编辑器设置。核心目标是提升编码效率、获得智能提示、快速跳转和便捷调试能力…

    2025年12月16日
    000
  • 深入探索Go语言交互式调试:从GDB到Delve

    Go语言的交互式调试功能至关重要,开发者可通过多种工具实现断点设置、单步执行等操作。本文将首先介绍传统的GDB调试方式及其在IDE中的集成,随后重点阐述Go语言原生调试器Delve的优势与使用,并结合主流IDE提供详细的调试实践指南,助您高效定位和解决Go程序中的问题。 Go语言调试基础:GDB 在…

    2025年12月16日
    000
  • Golang本地调试环境搭建与常见问题解析

    正确安装并配置Delve是搭建Golang本地调试环境的核心。首先确认Go已安装并设置环境变量,推荐使用Go Modules管理依赖,通过go mod init初始化项目;接着执行go install安装Delve调试器,运行dlv version验证安装,macOS用户需注意代码签名问题;然后在V…

    2025年12月16日
    000
  • Golang IDE集成开发环境配置与调优

    答案:本文以VS Code为例,介绍Go语言开发环境的配置与优化。需安装最新版VS Code及官方 Go 扩展,并确保 Go 环境(建议1.19+)正确安装;首次打开 .go 文件时自动安装 gopls(语言服务器)、delve(调试器)等工具。关键工具包括 goimports(自动格式化与导入管理…

    2025年12月16日
    000
  • Golang开发环境调试工具配置与使用方法

    Delve是Go官方推荐调试工具,通过go install安装后可用dlv debug启动调试,支持命令行与VS Code图形化调试,配合launch.json配置可实现断点、变量查看等功能,关闭编译优化可解决断点失效与变量优化问题。 Go语言开发中,良好的调试工具能大幅提升开发效率。合理配置调试环…

    2025年12月16日
    000
  • Go语言文件命名规范:以下划线或点号开头文件的特殊处理

    Go语言的go build命令会忽略文件名以下划线或点号开头的源文件。这一行为由标准库go/build包定义,旨在排除临时文件或编辑器相关文件。因此,开发者应避免使用此类命名方式来定义包的有效源代码,否则其中定义的函数和类型将无法被导入和使用,影响程序的正常构建和运行。 Go构建工具的文件识别机制 …

    2025年12月16日
    000
  • Go 语言中以 _ 开头的文件行为解析

    本文深入探讨了Go语言中以 _ 或 . 开头的文件在 go build 命令下的特殊处理机制。这些文件通常被Go工具链视为非源码文件而忽略,导致其中定义的函数和类型无法被编译和导入。文章将解析其背后的原理,提供示例说明,并给出在Go项目开发中文件命名和管理方面的最佳实践与注意事项。 Go 文件命名约…

    2025年12月16日
    000
  • Golang环境搭建如何在不同操作系统统一配置

    统一Go版本管理、环境变量、项目结构和工具链,使用gvm/Scoop管理版本,标准化GOPATH、GO111MODULE,通过Go Modules确保依赖一致,配置VS Code与golangci-lint统一开发环境,提升跨平台协作效率。 在不同操作系统(Windows、macOS、Linux)中…

    2025年12月16日
    000
  • Golang开发环境性能优化与调优技巧

    优化Golang开发环境需从依赖管理、编译构建、IDE响应和测试调试四方面入手。配置GOPROXY使用国内镜像如goproxy.cn可加速模块下载,开启GOCACHE并定期清理提升缓存效率;通过增量编译、禁用CGO、调整GOMAXPROCS优化构建速度;在IDE中限制gopls内存、排除无关目录、关…

    2025年12月15日
    000
  • Golang集成VSCode开发环境设置

    安装Go扩展并配置环境变量和gopls语言服务器,再安装Delve调试工具,即可在VSCode中实现代码补全、跳转、格式化和调试功能。 要在VSCode中高效开发Golang项目,关键在于正确配置编辑器和相关工具。只要装好插件并设置好路径,写Go代码会非常顺畅。 安装Go扩展 打开VSCode,在扩…

    2025年12月15日
    000
  • Golang使用VSCode调试Go程序实践

    首先安装Go SDK、VSCode Go扩展和Delve调试器,然后在项目根目录创建.vscode/launch.json配置文件,设置断点后按F5启动调试,可实现变量查看、调用栈分析及步进操作,配合args和env字段支持参数传递与环境变量设置。 在Go语言开发中,VSCode是一个轻量又高效的选…

    2025年12月15日
    000
  • Golang集成调试工具Delve配置方法

    Delve是Go语言专用调试器,通过go install安装后可用dlv debug调试主程序,支持断点、变量查看及VS Code图形化调试,还可配置headless模式实现远程调试,需注意权限、路径与版本兼容性。 在Go语言开发中,调试是必不可少的一环。Delve(dlv)是专为Go设计的调试器,…

    2025年12月15日
    000
  • Golang配置IDE自动补全与环境关联

    答案:配置Golang开发环境需确保IDE正确识别Go SDK、安装gopls语言服务器并初始化go.mod文件。首先安装Go SDK并配置系统PATH,验证go version和go env;接着在VS Code中安装官方Go扩展,通过go install命令安装gopls、dlv等工具,确保GO…

    2025年12月15日
    000
  • Golang云开发环境 Gitpod云端IDE

    答案:Gitpod是基于浏览器的云端IDE,可快速搭建Golang开发环境,免去本地配置,支持自动初始化、调试和版本控制,提升开发效率。 Golang云开发环境 Gitpod云端IDE,简单来说,就是利用Gitpod这个云端IDE,搭建一个方便快捷的Golang开发环境,省去了本地配置的麻烦。 Gi…

    2025年12月15日
    000

发表回复

登录后才能评论
关注微信