前端vscode代码格式化统一

背景

项目参与成员过多,代码风格不统一,导致代码片段五花八门,不方便预览和代码review。因此一个好的代码风格和格式化要求,在项目初期阶段至关重要。

🤡个人觉得代码能跑,格式化时别太多代码提交冲突,选一个用就行了。推荐Prettier吧,文章底部不是说Eslint妥协了么...

  • ESLint是用于检查和修复代码中的问题,如语法错误、潜在的错误、代码风格问题等。
  • Prettier指定代码格式化的规则,例如缩进、换行符、引号样式等。会根据这些规则自动格式化代码,以确保整个项目中的代码风格一致。它不会执行静态代码分析或对代码进行修复,仅用于格式化代码。

ESLint+Prettier配合使用,才能达到真正意义上的代码格式化。但是往往有ESLint的情况下,代码规范会更加严格,所以可以根据自身项目要求去配置。

安装扩展

前提需要在vscode中下载 ESLint,Prettier-Code formatter扩展插件

配置ESLint

sql 复制代码
npm install eslint --save-dev

初始化eslint,选择你要生成的模板等初始化信息,然后会生成.eslintrc.js文件。其中的具体校验内容和信息可以根据自身项目要求进行配置。

.eslintrc.js:ESLint是一款静态代码分析工具,用于检查和修复代码中的问题,如语法错误、潜在的错误、代码风格问题等。.eslintrc是用于配置ESLint的配置文件。你可以在该文件中指定ESLint的规则、插件、解析器等。ESLint会根据这些规则对代码进行静态分析,并根据规则定义的修复进行代码修复。

sql 复制代码
npx eslint --init

你也可以配置.eslintignore用来忽略一些需要跳过校验的文件

bash 复制代码
/build/
/config/
/dist/
# /*.js
**/router.js
/src/assets/

配置Prettier

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

创建.prettierrc.json文件,内部可以自定义代码格式化样式风格。

json 复制代码
{
  "tabWidth": 2, // 缩进字节数
  "endOfLine": "auto", // 结尾是 \n \r \n\r auto
  "printWidth": 120, // 超过最大值换行
  "proseWrap": "preserve", // 默认值。因为使用了一些折行敏感型的渲染器(如GitHub comment)而按照markdown文本样式进行折行
  "quoteProps": "as-needed", // 对象的 key 仅在必要时用引号
  "semi": true, // 句尾添加分号
  "singleQuote": true, // 使用单引号代替双引号
  "trailingComma": "none", // 在对象或数组最后一个元素后面是否加逗号(在ES5中加尾逗号)
  "useTabs": false, // 缩进不使用tab,使用空格
  "arrowParens": "always", // (x) => {} 箭头函数参数只有一个时是否要有小括号。avoid:省略括号
  "bracketSpacing": true, // 在对象,数组括号与文字之间加空格 "{ foo: bar }"
  "eslintIntegration": true, // 使用eslint进行格式化校验
  "vueIndentScriptAndStyle": true // 是否缩进Vue文件中<script>和<style>标记内的代码。
}

配置vscode设置

通过在setting.json配置相关属性,来确定是否在保存时等情况下是否进行格式化或者eslint校验等,打开方式shift+ctrl+p

json 复制代码
{  "editor.formatOnSave": true //保存时自动格式化代码 }

你可能会在一些项目中不想保存后对整个文件进行格式化,那你可以通过配置esbenp.prettier-vscode

json 复制代码
{
    "[javascript]": {
	"editor.defaultFormatter": "esbenp.prettier-vscode"
     }
}

可能对你有帮助

相关推荐
-To be number.wan1 小时前
C++ 赋值运算符重载:深拷贝 vs 浅拷贝的生死线!
前端·c++
噢,我明白了1 小时前
JavaScript 中处理时间格式的核心方式
前端·javascript
纸上的彩虹2 小时前
半年一百个页面,重构系统也重构了我对前端工作的理解
前端·程序员·架构
be or not to be2 小时前
深入理解 CSS 浮动布局(float)
前端·css
LYFlied3 小时前
【每日算法】LeetCode 1143. 最长公共子序列
前端·算法·leetcode·职场和发展·动态规划
老华带你飞3 小时前
农产品销售管理|基于java + vue农产品销售管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
小徐_23333 小时前
2025 前端开源三年,npm 发包卡我半天
前端·npm·github
GIS之路4 小时前
GIS 数据转换:使用 GDAL 将 Shp 转换为 GeoJSON 数据
前端
JIngJaneIL4 小时前
基于springboot + vue房屋租赁管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
天天扭码4 小时前
以浏览器多进程的角度解构页面渲染的整个流程
前端·面试·浏览器