zoukankan      html  css  js  c++  java
  • prettier代码格式化工具

    1.两大linter说起

    • eslint 为js而设计的可插拔的检查程序
    • tslint 为ts语言而设计的可扩展的检查工具(将在2019年取消更新,建议使用eslint)

    两种linter都可以实现fix功能,所谓fix就是将原代码转化为符合一定规则的新代码。虽然linter工具fix之后的代码,解决了大部分问题,但可能有些地方并不符合我们的阅读代码的习惯,比如一行代码过长。

    在强迫症的影响下,不同的人对自己的代码进行不同程度的”美化“,甚至遇到他人代码时也会顺手美化一把。

    最终导致项目中的代码风格不能统一。

    2.prettier简介

    prettier是一种保证代码一致性、兼具美化效果的代码格式化工具

    2.1 not only js

    前有jslint,而后由于eslint过于成功,导致了jslint已经无人问津,这也让我们误以为eslint只专注于js
    下面列举了它所支持的其他语言

    • JavaScript、jsx
    • flow、typescript
    • json
    • css、less、scss
    • graphql
    • markdown
    • yaml

    2.2 IDE

    有人的地方就有江湖,有编辑器的地方就有prettier,目前流行的ide都能支持prettier

    • vscode
    • webstorm
    • atom
    • visual studio
    • sublime

    以上列举了前端比较常用的几个工具,需要确定所使用的的编辑器是否支持prettier是否支持,请移步官网

    2.3 parser

    prettier针对不同的语言,所使用的的parser有多个,例如编译graphql时所使用的就是graphql/language。
    而编译js的目前有两个,即babylon(默认)、flow,由于babylon的bug较少,对编译工作支持度较好,所以默认情况下选用babylon即可。
    babylon即babel6的编译工具,在babel7中已更名为@babel/parser

    资源搜索网站大全 http://www.szhdn.com 广州VI设计公司https://www.houdianzi.com

    3.eslint融合

    eslint作为强大的linter工具,与vscode配合后能降低代码问题的风险,在coding的过程中就发现潜在问题,提高代码质量。

    3.1 eslint-config-prettier

    eslint的config可以继承自第三方包的config,config中定义了rules的开关规则,eslint-config-prettier主要定义了prettier格式化后导致eslint报错的那些规则

    3.2 eslint-plugin-prettier

    eslint与prettier的格式化需要分别进行,如果想要让eslint fix的同时,也能兼顾prettier的规则进行格式化,就需要使用到eslint-plugin-prettier这个插件。

    它的主要作用就是专门定义了eslint fix的prettier规则

    3.3 融合写法

    在.eslintrc文件中加入以下配置

    {
      "extends": ["plugin:prettier/recommended"]
    }

    这段代码有三个作用

    • 继承prettier的config规则
    • 开启rules的 "prettier/prettier": "error"
    • eslint fix的同时执行prettier格式化
  • 相关阅读:
    WPF中Name和x:Name
    依赖注入(Dependency Injection)
    SQL复制表操作
    奇异值分解和聚类分析操作流程
    奇异值分解(SVD)
    js读取本地txt文件中的json数据
    Python对字典(directory)按key和value排序
    PowerDesigner导入java类生成类图
    python-Levenshtein几个计算字串相似度的函数解析
    编辑距离算法(Levenshtein)
  • 原文地址:https://www.cnblogs.com/xiaonian8/p/14019357.html
Copyright © 2011-2022 走看看