手動調整代碼格式,不只低效,並且在團隊協做開發中,沒法保證代碼風格統一,因此須要引入自動格式化代碼工具。Prettier不只能夠格式化js, jsx, vue,angular,ts,flow,還適用於HTML, CSS/Less,/Sass,Markdown, YAML, GraphQL代碼的格式化,javascript
{ 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-不格式化 }
{ "javascript.format.enable": false, // 禁用vscode默認的js格式化插件 "editor.formatOnSave": true, // 保存代碼的時候格式化 "[javascript]": { "editor.defaultFormatter": "esbenp.prettier-vscode" // js文件採用prettier進行格式化 }, }
配置完以後,保存代碼時,就有自動格式化的效果。css
prettier只關心代碼格式,這顯然是不夠的,咱們追求的目標不單單是代碼風格統一,還要在書寫的時候,避免一些常見的低級的錯誤。因此,就要引入ESlint。ESLint也有許多與代碼規則有關的配置項,那你可能要問,我只用eslint就行了,既能規範編碼風格,也能提高代碼質量。何須兩個都用,用了還容易起衝突,這是由於eslint的代碼格式化有盲區,只針對js,jsx,ts,tsx,不能格式化HTML, CSS/Less,/Sass,Markdown, YAML, GraphQL,以及vue中的html和css。html
Prettier的功能比較專注,是專門用來格式化代碼的,格式化代碼的範圍比ESLint普遍。vue
ESLint的功能相對綜合,大致能夠分爲類,一類是規範代碼風格(見下圖),一類是規範代碼質量。java
它們之因此會衝突,就是由於井水犯了河水,功能有交叉,並且規則不一樣,好比Prettier格式化代碼,默認每行後面加分號,而ESLint的規則是不加,再好比Prettier格式化代碼時,字符串會用雙引號包起來,而ESLint的規則是單引號,由此就產生的衝突。node
要麼修改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" ] }
"editor.codeActionsOnSave": { "source.fixAll.eslint": true },
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