这篇关于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 是让代码保存后保持规范 */ }
总结
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]