一、prettier 介绍

官方自己介绍说,prettier是一款强势武断的代码格式化工具,它几乎移除了编辑器本身所有的对代码的操作格式,然后重新显示。就是为了让所有用这套规则的人有完全相同的代码。在团队协作开发的时候更是体现出它的优势。与eslint,tslint等各种格式化工具不同的是,prettier只关心代码格式化,而不关心语法问题。

目前在github上已经有了31.5k的star。

prettier 的优势也很明显,它支持 HTML/JS/JSX/TS/JSON/CSS/SCSS/LESS/VUE 等主流文件格式。下面这张图可以很好的进行说明:

也支持目前市面上所有主流的编辑器:

二、prettier 的使用

prettier的使用可分为两种方式:

1、使用编辑器的插件

使用编辑器插件是最为方便的一种方法,编写完代码,只需要一键即可格式化编写的代码,非常方便。这里已vscode为例进行说明,下面的配置是我自己的对于HTML/CSS/JS/LESS文件的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的代码格式进行校验
}
复制代码

上面只是一些基本的语言的格式化规范,prettier 每一个属性的配置都有详细的说明,大家可以根据自己的情况进行调整。

相信每个在vscode上编写vue的都会下载 Vetur 插件,它目前是 vscode 上面最好用的一款vue插件。现在要说的是,如何使用prettier格式化vue的代码。你没法使用类似格式化html/css/js的方式来格式化vue格式的代码,像下面这样子的:

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

这样prettier是不认识的。不过幸运的是,Vetur插件内部默认使用prettier进行格式化的,但是由于Vetur的默认格式化配置与我们期望的有所出入,所以我们需要单独对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保留}},
}
复制代码

这些配置是不会和之前配置的prettier规则冲突的。

值得提一句的是,Vetur对于html文件默认使用的是 prettyhtml,但是由于prettier也可以支持html的格式化,所以我觉得统一使用prettier对全语言的格式化是比较简洁的,也希望prettier能够对更多的语言进行支持。

2、使用脚本的方式

这种方式就是使用prettier指令在命令行窗口对单一文件进行格式化。 首先需要安装prettier全局指令:

npm install -g prettier
复制代码

可以使用 prettier -v 检查是否安装完成。

安装好之后,使用下面指令对xxx.js文件进行格式化(使用的是prettier默认的配置规则)。

// //prettier--write <文件路劲+文件名>prettier --write ./xxx.js
复制代码

当然,默认的配置规则是不符合我们的需求的,我们需要自定义配置规则。 书写自定义规则的文件需要是下面几种文件和格式:

  • .prettierrc 文件,支持yaml和json格式;或者加上 .yaml/.yml/.json 后缀名
  • .prettierrc.toml 文件(当为toml格式的时候,后缀是必须的)
  • prettier.config.js 或者 .prettierrc.js,需要返回一个对象
  • package.json文件中加上"prettier"属性

每种文件的书写格式如下: JSON

{"trailingComma": "es5","tabWidth": 4,"semi": false,"singleQuote": true
}
复制代码

JS

// prettier.config.js or .prettierrc.js
module.exports = {trailingComma: "es5",tabWidth: 4,semi: false,singleQuote: true
};
复制代码

YAML

# .prettierrc or .prettierrc.yaml
trailingComma: "es5"
tabWidth: 4
semi: false
singleQuote: true
复制代码

TOML

# .prettierrc.toml
trailingComma = "es5"
tabWidth = 4
semi = false
singleQuote = true
复制代码

prettier 查找配置的方式首先会找当前目录下,使用以下指令格式化代码:

//prettier --config --write <文件路劲+文件名>prettier --config --write ./xxx,js
复制代码

如果prettier在当前目录找不到配置文件,会一直向上级目录查找,直到找到或找不到。如果我们配置文件放在别的地方,则需要手工指定配置文件的路径:

// prettier --config <配置文件路径+文件名> --write <文件路劲+文件名>prettier --config ./prettier/.prettierrc --write ./xxx.js
复制代码

如果觉得每次格式化一个文件比较麻烦,可以使用下面的指令,一次格式化所有文件:

prettier --config ./prettier/.prettierrc --write './*.{ts,js,css,json}'
复制代码

我们一般使用这种方式的时候,就把这个配置文件写在项目根路径下,然后使用命令行一次性格式化项目下的所有文件。

三、以上两种方式对比

上面两种方式各有优劣,我们来分析一下各自的使用场景和一些问题:

第一种方式其实适合个人开发,第二种方式适合团队开发。

至于为什么这么说,就要考虑到二者的优先级问题了。上面两种方式如果同时存在的话,会有优先级的问题。 .prettierrc 的优先级会高于在vscode全局配置settings.json中格式化配置的优先级

也就是说,如果你在一个项目中有 .prettierrc 配置文件,然后你又在settings.json也配置了格式化规则,那么当你在vscode编辑器中对一个文件点击鼠标右键[格式化文档]的时候,格式化规则会以 .prettierrc 为准。

所以,由于编辑器settings.json每个人的设置可能都不一样,要求每个人统一设置也不方便操作,而嵌入在项目中的配置文件则可以随着项目到达各个开发者,而且会覆盖每个开发者的不同代码喜好,真正做到团队代码统一的效果。

以上就是所有我对prettier理解的内容,希望对你有帮助。更多精彩内容可以关注我的微信公众号[前端队长],我们一同成长,一同领略技术与生活“落霞与孤鹜齐飞,秋水共长天一色”的美好。

参考链接:

blog.csdn.net/wxl1555/art…

juejin.im/post/5bfcde…

segmentfault.com/a/119000001…

超人气代码格式化工具prettier相关推荐

  1. 代码格式化工具Prettier

    Prettier安装使用及配置项参考官方文档,文档更全更清晰 Prettier文档 GitHub Vscode:启用Prettier格式化 {// 将默认格式化工具设置为prettier"e ...

  2. Prettier 1.15代码格式化工具新增Angular和Vue.js支持

    Prettier 1.15代码格式化工具新增HTML.Vue.js.Angular.MDX支持以及多项语法优化和改进. 对于Angular和Vue,Prettier现在可以格式化这些扩展HTML的框架 ...

  3. 代码格式化工具:pretter

    代码格式化工具:pretter 文章目录 代码格式化工具:pretter 安装prettier 设置格式化的风格 设置不需要使用.pretter格式化的文件 运行查看 ​ 相信大家在编写js代码的时候 ...

  4. VSCode配置格式化工具(Prettier/Vetur/ESLint)和jsconfig.json

    VSCode配置格式化工具(Prettier/Vetur/ESLint) 网上很多配置,有的过时了, 有的很杂, 自己看了下文档,简单配置了以下, 顺便记录下来. 准备 用vue-cli建好项目之后, ...

  5. 下载频道2013下半年超人气精华资源汇总---全都是免积分下载。

    下载频道2013下半年超人气精华资源汇总---全都是免积分下载. 十分感谢这些免积分分享精华资源的好人!! 转自:http://bbs.csdn.net/topics/390674613 Androi ...

  6. 推荐一个小而美的Python代码格式化工具

    代码可读性是评判代码质量的标准之一,有一个衡量代码质量的标准是 Martin 提出的 "WFT" 定律,即每分钟爆出 "WTF" 的次数.你在读别人代码或者做 ...

  7. python格式化代码工具_python 代码格式化工具:YAPF

    背景 现在的大多数 Python 代码格式化工具(比如:autopep8 和 pep8ify)是可以移除代码中的 lint 错误.这显然有些局限性.比如:遵循 PEP 8 指导的代码可能就不会被格式化 ...

  8. php代码格式化工具 php-cs-fixer的使用

    为什么80%的码农都做不了架构师?>>>    php-cs-fixer简介 php-cs-fixer 是个代码格式化工具,格式化的标准是 PSR-1.PSR-2 以及一些 symf ...

  9. PyCharm 代码格式化工具:black

    black 简介 自动的代码格式化工具,兼容 pep8,项目地址为: black项目地址 官方给出的简介: Black is the uncompromising Python code format ...

最新文章

  1. 后台开发经典书籍--Kafka权威指南
  2. 垃圾“程序是怎样练成的”——关于《C程序设计伴侣》第A章(四)
  3. 使用git实现免密操作、TortoiseGit实现SSH免密码操作
  4. bzoj2753: [SCOI2012]滑雪与时间胶囊
  5. session图片验证码,页面和请求是两个地址。android手机好用,iphone 失效。
  6. win8选择哪个python版本_Win8的几个版本该怎么选
  7. 【读书笔记】实战JAVA虚拟机JVM故障诊断与性能优化 读书笔记
  8. cuSPARSE库:(十)cusparseCreateMatDescr()
  9. 360gen9装linux找不到硬盘,H3C案例查看:针对HPE ProLiant Gen8/Gen9系列服务器在Linux系统下如何开启......
  10. 打破网络沉闷---QQ强制聊天工具再度现身!
  11. python切片读取数据_在Python中读取、切片和重组数据文件blockbyblock
  12. 数据库和 MIDP,第二部分:数据映射
  13. 在VUE中实现城市及对应的地区的联动渲染
  14. 10-N个你可能不知道的Mixly软件操作小技巧 | Mixly技巧系列
  15. 拨号时显示无法连接服务器失败,拨号网络常见的错误提示解释及解决方法大全...
  16. 安卓盒子 魔百盒311-1a YST 刷Armbian系统刷机教程
  17. matlab流场可视化后处理
  18. 西南(唐山)交通大学上海校友会第四届理事会第一次会议成功召开
  19. Oracle的软件产品是用什么开发出来的
  20. Python代码编译,py文件编译为pyc文件

热门文章

  1. win7怎么进网络连接服务器未响应,win7 怎么远程连接服务器未响应
  2. C语言:数组与指针之 p++ 操作的细节问题(p是指针)
  3. baby计算机英语怎么读,英语单词baby怎么读,baby的音标是什么,baby是什么意思 - 音标网...
  4. 学习LDPC码的一些入门笔记
  5. 发表 SCI 封面文章是一种怎样的体验?
  6. 卡西欧计算器——三角函数的角度模式与弧度模式的切换
  7. matlab e52pt,帮我看看Matlab怎么改这个错误?
  8. React Routing
  9. 又火了一本神书,看小说就能学 JavaScript?
  10. REST模式:POST,GET,PUT,DELETE,PATCH的含义与区别