2020最新版vscode格式化代码的详细教程

 更新时间:2020年08月10日 10:29:13   作者:wsdchong之小马过河  
这篇文章主要介绍了2020最新版vscode格式化代码的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

这篇关于vscode格式化配置研究初稿,具体内容如下所示:

前言

之前用vscode进行格式化的时候都是在百度和谷歌上搜“vscode格式化代码”然后直接copy别人。细节的配置一直没去看过。

但是最近一段时间开发项目的时候发现和同组的提交代码的时候格式总是不统一。于是这两天专门看了看插件的官方文档,研究研究。

今天初步有一点研究结果了。会配置一点点了。写此博客与大家共同参考。不足的地方欢迎大家补充,错误的地方欢迎大家纠错。

文章内容包括两个部分:一是理论,二是我的settings.json的配置。

理论

参考文章:

VSCode程序猿彩虹屁插件rainbow fart体验篇

vscode 配置vue+vetur+eslint+prettier自动格式化功能

vscode 配置vue+vetur+eslint+prettier自动格式化功能

代码格式化目的:

代码格式化的目的一是为了提高代码可读性,方便自己编码,方便团队开发;二是方便找出和修正因为格式导致的错误。

在团队开发。因为每个人的编码习惯不同,如

  • 缩进是2还是4。
  • 代码结尾是否加分号,用单引号还是用双引号。
  • 函数和后面的括号之间是否加个空格。
  • 等等

统一代码格式,让每个人开发更顺利。

为了完成第一个目的,格式化插件有vetur、prettier等针对文件进行格式化的插件;

为了完成第二个目的,格式化插件有ESlint等对文件进行代码检验的插件。

代码格式化的注意事项:

插件作用

首先明白格式化插件分别侧重格式化哪些文件,因为不同的文件有不同的格式规范。

prettyhtml格式化HTML;
prettier格式化css/less/scss/postcss/ts;
stylus-supremacy格式化stylus;
vscode自带格式化插件格式化js;
vetur格式化.vue文件;让不同块使用不同的格式化方案
ESlint:新版的ESlint支持了对.vue文件的校验。

符合代码检验

然后注意让格式化的代码符号ESlint代码检验。

格式化代码最重要的是两点,一点是用格式化插件格式化对应的文件;另一点是让格式化后的代码能通过代码检验工具。

举个例子。

Prettier插件不支持在函数名后面加上括号。这点和ESlint冲突了。所以js的格式化不能使用prettier插件格式化,而是使用vscode自带的js格式化功能来格式化。否则ESlint就是报错,简直烦死强迫症。

插件更新

最后要注意插件的是插件不断更新的,所以网上直接copy的格式化代码会各种不兼容。

如vscode 的 ESLint 插件在某个版本已经移除了 "eslint.validate" 这个配置选项,而网上很多教程都是使用的这个。

在新版的 ESLint 中已经支持了对 *.vue 文件的校验,所以无需再进行这项配置了,只需要添加一个保存时自动修复 ESLint 错误的功能就行了。

代码格式化插件的官方文档:

语言介绍

pug:官方文档 。pug是一款专门为node.js平台开发的HTML模块引擎。

less:官方文档。less是一门CSS预处理语言。

scss:官方文档。scss(sass)是世界上最成熟、稳定强大的专业级CSS预处理语言。

postcss:官方文档。postcss是使用js插件来转换CSS的工具。

stylus:官方文档。stylus是node.js平台上的CSS预处理框架。

插件介绍

vetur:官方文档。代码高亮、emmet语法支持、语法错误校验检查、代码提醒、格式化vue。
vetur集成了prettier,让.vue文件中不同的块使用不同的格式化方案,template标签调用 html 格式化工具,script标签调用 JavaScript 格式化工具,style标签使用style格式化工具。

ESlint:官方文档。代码检验。

prettyhtml:官方文档。为vue或纯HTML模板等提供通用格式化的工具。

pretties:官方文档。代码格式化工具,能够解析代码,使用用户设定的规则格式化规范的代码。

stylus-supremacy:官方文档。用于格式化stylus文件的node.js模块。

我的settings.json文件

{
 /*格式化文件对应插件:
主要是两步,一步是用格式化插件格式化对应的文件;
另一步让格式化后的代码能通过代码检验工具。
prettyhtml格式化HTML;prettier格式化css/less/scss/postcss/ts;
stylus-supremacy格式化stylus;
vscode自带格式化插件格式化js;
vetur格式化.vue文件;
ESlint进行代码检验。
*/

 /*格式化思路和注意事项。
注意格式化的代码能符合ESlint代码检验。
1.用vetur设置默认格式化工具。格式化.vue文件
2.用ESlint设置保存时修复ESlint错误的功能。
3.用prettier格式化css;去除语法结尾的分号,使用单引号替换双引号。
4.保存时自动格式化。
*/

 // 默认使用prettier格式化支持的文件
 "editor.defaultFormatter": "esbenp.prettier-vscode",

 "vetur.format.defaultFormatter.html": "prettyhtml",
 "vetur.format.defaultFormatter.css": "prettier",
 "vetur.format.defaultFormatter.postcss": "prettier",
 "vetur.format.defaultFormatter.scss": "prettier",
 "vetur.format.defaultFormatter.less": "prettier",
 "vetur.format.defaultFormatter.stylus": "stylus-supremacy",
 // "vetur.format.defaultFormatter.js": "prettier",
 "vetur.format.defaultFormatter.ts": "prettier",
 "vetur.format.defaultFormatter.sass": "sass-formatter",
 "open-in-browser.default": "Chrome",

 // 将vetur的js格式化工具指定为vscode自带的
 "vetur.format.defaultFormatter.js": "vscode-typescript",
 // 移除js语句的分号
 "javascript.format.semicolons": "remove",
 // 在函数名后面加上括号,类似这种形式 foo () {}
 "javascript.format.insertSpaceBeforeFunctionParenthesis": true,

 // eslint配置项,保存时自动修复错误。
 "editor.codeActionsOnSave": {
 "source.fixAll": true
 },

 // 指定 *.vue 文件的格式化工具为vetur
 "[vue]": {
 "editor.defaultFormatter": "octref.vetur"
 },
 // 指定 *.js 文件的格式化工具为vscode自带
 "[javascript]": {
 "editor.defaultFormatter": "vscode.typescript-language-features"
 },

 "vetur.format.defaultFormatterOptions": {
 "JS-beautify-HTML": {
 // JS-beautify-HTML的设置在这里
 "wrap_attributes": "force-aligned"
 },
 " prettyhtml": {
 "printWidth'": 100, // 每一行不超过100个字符
 "singleQuote": false, // 不用单引号
 "wrapAttributes": false,
 "sortAttributes": true
 },
 "prettier": {
 // 去掉代码结尾的分号
 "semi": false, //不加分号
 "singleQuote": true, //用单引号
 // #让prettier使用eslint的代码格式进行校验
 "eslintIntegration": true,
 "arrowParens": "always"
 }
 },

 // vscode默认启用了根据文件类型自动设置tabsize的选项
 "editor.detectIndentation": false,
 // 重新设定tabsize
 "editor.tabSize": 2,

 // 保存时自动格式化代码
 "editor.formatOnSave": true,

 //可选项。stylus的格式化配置以及sass格式化配置。
 // 格式化stylus, 需安装Manta's Stylus Supremacy插件
 "stylusSupremacy.insertBraces": false, // 是否插入大括号
 "stylusSupremacy.insertColons": false, // 是否插入冒号
 "stylusSupremacy.insertSemicolons": false, // 是否插入分号
 "stylusSupremacy.insertNewLineAroundImports": false, // import之后是否换行
 "stylusSupremacy.insertNewLineAroundBlocks": false,
 // 启用调试模式。
 "sass.format.debug": false,
 // 删除空格
 "sass.format.deleteEmptyRows": true,
 // 删除最后一个空格。
 "sass.format.deleteWhitespace": true,
 // 将 scss / css 转换为 sass。
 "sass.format.convert": true,
 // 如果 属性:值 为true,则始终设置为1.
 "sass.format.setPropertySpace": true

 /*格式化插件:
//vetur:代码高亮、emmet语法支持、语法错误校验检查、代码提醒、格式化vue。
vetur集成了prettier,让.vue文件中不同的块使用不同的格式化方案,
<template> 调用 html 格式化工具,
<script> 调用 JavaScript 格式化工具,
<style> 使用style格式化工具。

//ESlint:新版的ESlint支持了对.vue文件的校验。

//prettyhtml:为纯HTML模板等提供通用格式化的工具。
//prettier:格式化工具,用于css/less/scss/postcss/ts
//stylus-supremacy:用于格式化stylus文件的node.js模块。
//js的格式化工具用vscode自带的。
Prettier不支持在函数名后面加上括号。这点和ESlint冲突了。

//EditorConfig:主要是用于让 vscode 支持.editorconfig 文件。
.editorconfig 文件中的设置用于在基本代码库中维持一致的编码风格和设置,
例如缩进样式、选项卡宽度、行尾字符以及编码等。
EditorConfig 是让代码创建前保持规范,
Prettier 是让代码保存后保持规范
*/
}

总结

到此这篇关于2020最新版vscode格式化代码的详细教程的文章就介绍到这了,更多相关vscode格式化代码内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Git集成IDEA并连接GitLab全过程

    Git集成IDEA并连接GitLab全过程

    本文介绍了如何下载安装Git、IDEA中如何集成Git以及如何将IDEA项目连接到GitLab或GitHub,首先,详细介绍了Git的下载安装过程,并通过右键菜单检查安装成功,接着,展示了在IDEA中配置Git路径,并测试集成是否成功
    2024-11-11
  • Git中使用.gitignore忽略文件的推送方式

    Git中使用.gitignore忽略文件的推送方式

    这篇文章主要介绍了Git中使用.gitignore忽略文件的推送方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • 如何使用 Merklized 抽象语法树压缩智能合约

    如何使用 Merklized 抽象语法树压缩智能合约

    Merklized 抽象语法树 MAST(又名 Merklized 替代脚本树)是一种使用 Merkle 树压缩比特币智能合约的技术,这篇文章主要介绍了使用 Merklized 抽象语法树压缩智能合约,需要的朋友可以参考下
    2023-12-12
  • git通过内网代理访问外网的相关配置方法

    git通过内网代理访问外网的相关配置方法

    这篇文章主要介绍了git通过内网代理,访问外网的相关配置,配置git代理以http代理为例,给大家详细讲解,需要的朋友可以参考下
    2023-05-05
  • JetBrains公司三大编辑器迭代循环模板快捷键详解

    JetBrains公司三大编辑器迭代循环模板快捷键详解

    这篇文章主要介绍了JetBrains公司三大编辑器迭代循环模板快捷键,如果快捷键无用,请到keymap中调整自己的快捷键,或者查看是否有应用占用了该快捷键,需要的朋友可以参考下
    2022-04-04
  • TCP协议详解_动力节点Java学院整理

    TCP协议详解_动力节点Java学院整理

    本文描述了TCP协议,首先简单介绍了TCP完成了一些什么功能;介绍了TCP报文格式,以及典型报文的数据格式。现在通过本文给大家详细介绍,感兴趣的的朋友一起看看吧
    2017-07-07
  • Git基本概述

    Git基本概述

    本文主要介绍了Git的基础知识。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • Visual Studio和Visual Studio Code之间有什么区别

    Visual Studio和Visual Studio Code之间有什么区别

    本文给大家介绍的是Visual Studio和Visual Studio Code之间有什么区别,希望对大家的学习能够有所帮助
    2020-02-02
  • vscode如何安装汉化和Python智能感知

    vscode如何安装汉化和Python智能感知

    VSCode(VisualStudioCode)是由微软研发的一款免费、开源的跨平台文本(代码)编辑器,算是目前前端开发几乎完美的软件开发工具。今天我们来看看它如何使用呢
    2020-01-01
  • 在ubuntu18.04版本安装vscode(2种)

    在ubuntu18.04版本安装vscode(2种)

    这篇文章主要介绍了在ubuntu18.04版本安装vscode,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-05-05

最新评论