VSCode的prettier插件可以很方便的帮助我们格式化文档,但是对于HTML文件的格式化并不友好,每次我使用prettier格式化之后,html标签都会换行,这样html标签之间的结构就不是很清楚了,看起来很费劲。

格式化之后就成了这样:

vscode上html5提示插件_html


搜索了很久怎样让prettier格式化html时不换行,但都没有结果,现在发现可以通过设置prettier超过最大宽度换行的值来调整是否换行,效果不错。

打开VSCode的设置界面,设置prettier插件的Print Width值:

vscode上html5提示插件_ci_02


此时格式化之后,结构就清晰多了:

vscode上html5提示插件_ci_03


当然,具体想格式化成什么样子,还需要自己配置,下面是prettier插件的一些配置参数:

{
    // 使能每一种语言默认格式化规则
    "[html]": {
        "editor.defaultFormatter": "esbenp.prettier-vscode"
    },
    "[css]": {
        "editor.defaultFormatter": "esbenp.prettier-vscode"
    },
    "[less]": {
        "editor.defaultFormatter": "esbenp.prettier-vscode"
    },
    "[javascript]": {
        "editor.defaultFormatter": "esbenp.prettier-vscode"
    },

    /*  prettier的配置 */
    "prettier.printWidth": 100, // 超过最大值换行
    "prettier.tabWidth": 4, // 缩进字节数
    "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.disableLanguages": ["vue"], // 不格式化vue文件,vue文件的格式化单独设置
    "prettier.endOfLine": "auto", // 结尾是 \n \r \n\r auto
    "prettier.eslintIntegration": false, //不让prettier使用eslint的代码格式进行校验
    "prettier.htmlWhitespaceSensitivity": "ignore",
    "prettier.ignorePath": ".prettierignore", // 不使用prettier格式化的文件填写在项目的.prettierignore文件中
    "prettier.jsxBracketSameLine": 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": "es5", // 在对象或数组最后一个元素后面是否加逗号(在ES5中加尾逗号)
    "prettier.tslintIntegration": false // 不让prettier使用tslint的代码格式进行校验
}

格式化vue代码配置

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

Vetur结合prettier使用,单独对 Vetur 的 prettier 进行配置,如下:

{
   "vetur.format.defaultFormatter.html": "prettier",
   "vetur.format.defaultFormatter.js": "prettier",
   "vetur.format.defaultFormatter.less": "prettier",
   "vetur.format.defaultFormatterOptions": {
       "prettier": {
           "printWidth": 160,
           "singleQuote": true, // 使用单引号
           "semi": true, // 末尾使用分号
           "tabWidth": 4,
           "arrowParens": "avoid",
           "bracketSpacing": true,
           "proseWrap": "preserve" // 代码超出是否要换行 preserve保留
       }
   },
}