VSCode-Prettier和ESLint如何和氣共處?

1 在VSCode中單獨使用Prettier保存代碼自動格式化的配置方法

1.1 爲何要使用Prettier?

手動調整代碼格式,不只低效,並且在團隊協做開發中,沒法保證代碼風格統一,因此須要引入自動格式化代碼工具。Prettier不只能夠格式化js, jsx, vue,angular,ts,flow,還適用於HTML, CSS/Less,/Sass,Markdown, YAML,  GraphQL代碼的格式化,javascript

1.2 Prettier代碼格式化規則有哪些?

{
  printWidth: 80, // 超過最大值換行
  tabWidth: 2, // 縮進字節數
  useTabs: false, // 縮進不使用tab,使用空格
  semi: true, // 句尾添加分號
  singleQuote: false, // 使用單引號代替雙引號
  quoteProps: 'as-needed', // 對象的key是否用引號括起來,有三種選項 "as-needed"|"consistent"|"preserve"
  jsxSingleQuote: false, // 在jsx中使用單引號代替雙引號
  trailingComma: 'es5', // 選項:none|es5|all, 在對象或數組最後一個元素後面是否加逗號(在ES5中加尾逗號)
  bracketSpacing: true, // 是否在對象的{}內部兩側加空格 true - { foo: bar } false - {foo: bar}.
  jsxBracketSameLine: false, // 在jsx中把'>' 是否單獨放一行
  arrowParens: 'avoid', // (x) => {} 箭頭函數參數只有一個時是否要有小括號。avoid:省略括號 'bracketSpacing': true, // 在對象,數組括號與文字之間加空格 "{ foo: bar }"
  rangeStart: 0, // 僅格式化選中文本 選中文本格式化的起始位置
  rangeEnd: Infinity, // 選中文本格式化的結束位置
  parser: 'babylon', // 格式化的解析器,默認是babylon,會自動根據輸入文件推斷,不用更改設置
  requirePragma: false, // 若爲true,文件頂部加了 /*** @prettier */或/*** @format */的文件纔會被格式化
  insertPragma: false, // 當requirePragma參數爲true時,此參數爲true將向@format標記後面添加一個換行符
  proseWrap: 'preserve', // 有效選項[always|never|preserve]。當Markdown文本超過printWidth時,是否換行,always-換行 never-不換行 preserve保持原樣
  endOfLine: 'lf', // 結尾是 lf-\n cr-\r lfcr-\n\r  auto-保持現有的行尾設置
  htmlWhitespaceSensitivity: 'css', // 是否顯示HTML文件中的空格。 有效選項: 'css' - 尊重CSS display屬性的設置。 'strict' - 空格被認爲是敏感的。 'ignore' - 空格被認爲是不敏感的
  vueIndentScriptAndStyle: false, // 是否給vue中的 <script> and <style>標籤加縮進
  embeddedLanguageFormatting: 'auto', // 是否格式化嵌入到JS中的html標記的代碼段或者Markdown語法 auto-格式化 off-不格式化
}

1.3 如何開啓保存時代碼自動格式化?

1.3.1 下載Prettier插件

在vscode的配置文件中,設置保存代碼時使用prettier自動進行代碼格式化

{
  "javascript.format.enable": false, // 禁用vscode默認的js格式化插件
  "editor.formatOnSave": true, // 保存代碼的時候格式化
  "[javascript]": {
    "editor.defaultFormatter": "esbenp.prettier-vscode" // js文件採用prettier進行格式化
  },
}

 配置完以後,保存代碼時,就有自動格式化的效果。css

2.ESLint代碼校驗配置

2.1 有了Prettier以後,爲何還須要ESLint?

prettier只關心代碼格式,這顯然是不夠的,咱們追求的目標不單單是代碼風格統一,還要在書寫的時候,避免一些常見的低級的錯誤。因此,就要引入ESlint。ESLint也有許多與代碼規則有關的配置項,那你可能要問,我只用eslint就行了,既能規範編碼風格,也能提高代碼質量。何須兩個都用,用了還容易起衝突,這是由於eslint的代碼格式化有盲區,只針對js,jsx,ts,tsx,不能格式化HTML, CSS/Less,/Sass,Markdown, YAML,  GraphQL,以及vue中的html和css。html

2.2 Prettier和ESLint爲何會衝突?

Prettier的功能比較專注,是專門用來格式化代碼的,格式化代碼的範圍比ESLint普遍。vue

ESLint的功能相對綜合,大致能夠分爲類,一類是規範代碼風格(見下圖),一類是規範代碼質量。java

它們之因此會衝突,就是由於井水犯了河水,功能有交叉,並且規則不一樣,好比Prettier格式化代碼,默認每行後面加分號,而ESLint的規則是不加,再好比Prettier格式化代碼時,字符串會用雙引號包起來,而ESLint的規則是單引號,由此就產生的衝突。node

2.3 如何解決二者的衝突?

要麼修改Prettier的規則,使之與ESLint保持一致,要麼修改ESLint的校驗規則,使之與Prettier的代碼格式化風格一致,究竟要改哪個,均可以。我的傾向於改ESlint的規則,由於Prettier的代碼格式化規則是普適的,而ESLint的代碼校驗規則是針對特定語言的,特定的聽從普適的原則上好一些。react

 ESLint有關代碼風格的設置,有些是和Prettier衝突的,安裝eslint-config-prettier npm工具包,就能夠關閉eslint代碼風格部分與prettier衝突的設置。es6

yarn add  -D eslint-config-prettier

在.eslintrc.js中添加web

{
  "extends": [
    "some-other-config-you-use",
    "prettier"
  ]
}

2.3 vscode 保存時自動修復eslint報錯的配置

2.3.1 安裝ESLint插件

2.3.2 在.vscode中setting.json中開啓代碼保存自動修復eslint告警功能
  "editor.codeActionsOnSave": {
    "source.fixAll.eslint": true
  },
 2.3.3 在項目下添加.eslintrc.js文件,內容以下:
module.exports = {
  parser: 'babel-eslint',
  parserOptions: {
    // 想使用的額外的語言特性
    ecmaFeatures: {
      legacyDecorators: true, // 裝飾器
    },
  },
  // 添加共享設置
  settings: {
    polyfills: ['fetch', 'promises', 'url', 'object-assign'],
  },
  // extends 屬性值能夠省略包名的前綴 eslint-config-
  // 你可能想要將你的配置信息分享給其餘項目或人。可分享的配置容許你在 npm 發佈你的配置設置而且其餘人能夠在他的 ESLint 項目中下載使用這些配置。
  // 可共享的配置 是一個 npm 包,它輸出一個配置對象。
  extends: ['airbnb', 'prettier', 'plugin:compat/recommended'],
  // 插件通常是輸出規則,一些插件也能夠輸出一個或多個命名的 配置
  plugins: ['react'],
  // 指定腳本的運行環境。每種環境都有一組特定的預約義全局變量。
  env: {
    browser: true,
    node: true,
    es6: true,
    mocha: true,
    jest: true,
    jasmine: true,
  },
  globals: {
    localStorage: true,
    sessionStorage: true,
    WeixinJSBridge: true,
    screen: true,
    wx: true,
    qq: true,
    alert: true,
    Image: true,
    File: true,
    FormData: true,
    IntersectionObserver: true,
    fiboSDK: true,
  },
  rules: {  // 規則集,會覆蓋extends中的規則
    'react/jsx-filename-extension': [1, { extensions: ['.js'] }],
    'react/jsx-wrap-multilines': 0,
    'react/prop-types': 0,
    'react/forbid-prop-types': 0,
    'react/jsx-one-expression-per-line': 0,
    'import/no-unresolved': [2, { ignore: ['^@/', '^umi/'] }],
    'import/no-extraneous-dependencies': [0],
    'jsx-a11y/no-noninteractive-element-interactions': 0,
    'jsx-a11y/click-events-have-key-events': 0,
    'jsx-a11y/no-static-element-interactions': 0,
    'jsx-a11y/anchor-is-valid': 0,
    'linebreak-style': 0,
    'no-console': 0,
    'import/prefer-default-export': 0,
    'react/destructuring-assignment': 0,
    'consistent-return': 0,
    'no-return-assign': 0,
    'no-case-declarations': 0,
    'react/no-array-index-key': 0,
    'no-plusplus': 0,
    'no-param-reassign': 0,
    'no-useless-escape': 0,
    'array-callback-return': 0,
    'no-unused-expressions': 0,
    'no-underscore-dangle': 0,
    'no-lonely-if': 0,
    'func-names': 0,
    'react/no-access-state-in-setstate': 0,
    'react/no-did-update-set-state': 0,
    'no-restricted-syntax': 0,
    'no-nested-ternary': 0,
    'no-restricted-globals': 0,
    'react/jsx-props-no-spreading': 0,
    'class-methods-use-this': 0,
    'global-require': 0,
    'react/state-in-constructor': 0,
    'import/no-dynamic-require': 0,
    'react/no-danger': 0,
    'react/sort-comp': 0,
    'no-shadow': 0,
    camelcase: 0,
    //  不檢驗函數入參是否被使用
    'no-unused-vars': ['warn', { args: 'none' }],
  },
};

 

參考文獻express

[5]  eslint中文文檔  
相關文章
相關標籤/搜索