一、简介

  • 中文文档英文官网
  • Prettier 是一个开箱即用的代码格式化程序。用来批量处理旧代码的统一,涉及引号、分号、换行、缩进等。支持目前大部分语言处理,包括 JavaScriptFlowTypeScriptCSSSCSSLessJSXVueGraphQLJSONMarkdown ,它通过解析代码并使用自己的规则。

二、安装使用

  • vscode 需开启保存配置
  • 安装方式:
  • 方式一vscode 安装插件 Prettier,正常在项目文件根目录添加配置文件即可,会自动检测。
  • 方式二npm
$ npm install --save-dev --save-exact prettier
  • 方式三yarn
$ yarn add --dev --exact prettier
  • 配置文件有很多种写法,选一种就行,不用纠结,没必要给自己挖坑!

有安装 ESLint 的情况下,可以尝试将 Prettier 的配置偏向 ESLint 的校验结果。列一下常见的冲突点:

1、prettier 会默认把单引号变成双引号,然后 eslint 校验报错
2、js 每行代码后面会加一个分号,然后 eslint 校验报错
3、函数结束之后会加一个逗号,然后 eslint 校验报错
......

在项目根目录创建 .prettierrc.js,添加自己需要的配置,这里列了一下常用配置,包含上面冲突点的兼容,其他配置自动可额外添加(附:官方文档支持的配置属性

module.exports = {
  printWidth: 100,
  tabWidth: 2, // 超过最大值换行
  semi: false, // 结尾不用分号
  singleQuote: true, // 使用单引号
  disableLanguages: ['vue'], // 不格式化 vue 文件,vue 文件的格式化单独设置
  htmlWhitespaceSensitivity: 'ignore', // 标签换行不完整问题
  trailingComma: 'none', // 函数后面不加逗号,如果不写这一个,在methods 最后一个函数也会加逗号,eslint会报错,多了一个逗号
}
  • 项目中配置好之后,Ctrl + SCommand + S 保存
    如果保存无效,并没有进行格式化,在代码中右键菜单中,找到 使用...格式化文档 修改格式化文档方式为 Prettier,然后再次尝试保存,或者在右键菜单中直接点击 格式化文档
  • 可以忽略指定文件夹或文件中代码不进行格式化,以免提交出现冲突,创建 .prettierignore 文件,它使用的是 gitignore 语法
# Ignore artifacts:
build
coverage

# Ignore all HTML files:
*.html

三、补充

  • 基本配置效果对比
{
    // tab 缩进大小,默认为 2
    "tabWidth": 4,
    // 使用 tab 缩进,默认 false
    "useTabs": false,
    // 使用分号, 默认 true
    "semi": false,
    // 使用单引号, 默认 false (在 jsx 中配置无效, 默认都是双引号)
    "singleQuote": false,
    // 行尾逗号,默认 none ,可选 none|es5|all
    // es5 包括 es5 中的数组、对象
    // all 包括函数对象等所有可选
    "TrailingCooma": "all",
    // 对象中的空格 默认true
    // true: { foo: bar }
    // false: {foo: bar}
    "bracketSpacing": true,
    // JSX 标签闭合位置 默认 false
    // false: <div
    //          className=""
    //          style={{}}
    //       >
    // true: <div
    //          className=""
    //          style={{}} >
    "jsxBracketSameLine": false,
    // 箭头函数参数括号 默认 avoid 可选 avoid| always
    // avoid 能省略括号的时候就省略 例如x => x
    // always 总是有括号
    "arrowParens": "avoid"
}
  • vscode 安装插件之后,除了在项目中添加配置文件之外,也可以直接配置到 vscode 的配置文件( settings.json )中,这样就不需要每个项目添加配置文件了
// prettier配置,,修改了配置文件,必须重启 vscode 才会生效
  "prettier.configPath": "/Users/xxx/Desktop/Project/npm/dts-gen/.prettierrc.js", // 配置文件路径,配置了这个路径,就不需要单个配置了,要不然会覆盖
  "eslint.alwaysShowStatus": true, // 总是显示 eslint 状态
  "prettier.printWidth": 120, // 超过最大值换行
  "prettier.tabWidth": 2, // 缩进字节数
  "prettier.useTabs": false, // 缩进不使用 tab,使用空格
  "prettier.semi": true, // 句尾添加分号
  "prettier.singleQuote": true, // 使用单引号代替双引号
  "prettier.proseWrap": "preserve", // 默认值。因为使用了一些折行敏感型的渲染器(如 GitHub comment)而按照 markdown 文本样式进行折行
  "prettier.arrowParens": "avoid", //  (x) => {} 箭头函数参数只有一个时是否要有小括号。avoid:省略括号
  "prettier.bracketSpacing": true, // 在对象,数组括号与文字之间加空格 "{ foo: bar }"
  "prettier.endOfLine": "auto", // 结尾是 \n \r \n\r auto
  "prettier.eslintIntegration": false, // 不让 prettier 使用 eslint 的代码格式进行校验
  "prettier.htmlWhitespaceSensitivity": "ignore", // 标签换行不完整问题
  "prettier.ignorePath": ".prettierignore", // 不使用 prettier 格式化的文件填写在项目的.prettierignore文件中
  "prettier.BracketSameLine": false, // 在 jsx中 把 '>' 是否单独放一行
  "prettier.jsxSingleQuote": false, // 在 jsx 中使用单引号代替双引号
  // "prettier.parser": "babylon", // 格式化的解析器,默认是 babylon
  "prettier.requireConfig": false, // Require a 'prettierconfig' to format prettier
  "prettier.stylelintIntegration": false, // 不让 prettier 使用 stylelint 的代码格式进行校验
  "prettier.trailingComma": "none", // 属性值 es5 表示在对象或数组最后一个元素后面是否加逗号(在ES5中加尾逗号)
  "prettier.tslintIntegration": false, // 不让 prettier 使用 tslint 的代码格式进行校验