ESLint是一個開源的項目,由Nicholas C. Zakas(《JavaScript高級程序設計》做者)於2013年六月建立。它的目標是爲JavaScript提供一個徹底可配置的實用lint工具。前端
JavaScript是一種動態的、鬆散型的語言,是特別容易受到開發人員的錯誤使用。而ESLint能夠在不執行JavaScript代碼的狀況下發現代碼的問題。react
ESLint由Node.js編寫,經過NPM提供快速的運行環境,而且安裝方便。jquery
全局安裝npm
$ npm install -g eslint
本地安裝json
$ npm install eslint --save-dev
在你想要使用ESLint的工程根目錄下執行:promise
eslint --init
這個命令的目的是建立一個eslint配置文件。若是你是全局安裝的eslint,那麼能夠在任意文件中使用該命令,不然,你必須在使用該命令以前在該項目中安裝eslint。前端工程師
執行該命令後,通常會出現三個選項可供選擇,他們分別是:ide
❯ Answer questions about your style Use a popular style guide Inspect your JavaScript file(s)
在這以後, 在你的目錄中會有一個.eslintrc文件,這個.eslintrc的存在形式也是可選擇的,它能夠是JavaScript、YAML、JSON、package.json等等。工具
生成配置文件以後,打開.eslintrc文件(通常是隱藏的),能夠看到如下格式的內容:ui
{ "env": { "browser": true }, "extends": "eslint:recommended", "rules": { "indent": [ "error", "tab" ], "linebreak-style": [ "error", "unix" ], "quotes": [ "error", "double" ], "semi": [ "error", "always" ] }, Globals: { } }
我這個是json格式的,這裏解釋一下這個文件裏各個參數的意思:
env :指定你的js代碼在哪一個運行環境中檢測(每一個運行環境都有一組預約義的全局變量);
extends :擴展配置規則(),我這裏擴展的是eslint的推薦規則;
rules :指定檢測規則;
這是最重要的部分,也是你的自定義js代碼監測規則的地方,他的格式是:規則名: 規則。好比:
"indent": ["error","tab"]
這裏indent
就是規則名,它定義了縮進應該使用tab,規則內的第一個值error
指的是錯誤等級,它有三個等級,分別是:
error level | 數值表示 | 涵義 |
---|---|---|
error | 2 | 做爲錯誤 |
warn | 1 | 做爲提醒 |
off | 0 | 關閉該規則 |
更多的規則能夠參考官網的rules。
Globals :指定腳本執行過程當中訪問的附加全局變量(好比jquery)
PS:
您能夠配置全局的.eslint文件,而不至於要每一個工程中都建立一個獨有的.eslint文件,烹製方法是將您的.eslintr文件放在當前用戶的根目錄下,類Unix系統的當前用戶目錄是~
,而Windows系統的話則是相似於C:\Windows\Users\Username
這樣的地方
在你的工程目錄下執行:
eslint yourfile.js
它會在命令後輸出你的全部報錯信息。這樣就ok了。我的感受它的最大優點就是徹底可配置,並且配置文件一次構建,能夠經過粘貼複製的方式無數次使用。甚至整個團隊能夠經過使用一份配置文件來達到規範代碼的做用,仍是很強大的。
eslint官方提供了3種預安裝包:
Google標準
執行安裝:
npm install eslint eslint-config-google -g
Airbnb標準,它依賴eslint, eslint-plugin-import, eslint-plugin-react, and eslint-plugin-jsx-a11y等插件,而且對各個插件的版本有所要求。
你能夠執行如下命令查看所依賴的各個版本:
npm info "eslint-config-airbnb@latest" peerDependencies
你會看到如下輸出信息,包含每一個了每一個plugins的版本要求
{ eslint: '^3.15.0', 'eslint-plugin-jsx-a11y': '^3.0.2 || ^4.0.0', 'eslint-plugin-import': '^2.2.0', 'eslint-plugin-react': '^6.9.0' }
知道了每一個plugins的版本要求後,代入如下命令執行安裝便可使用:
npm install eslint-config-airbnb eslint@^#.#.# eslint-plugin-jsx-a11y@^#.#.# eslint-plugin-import@^#.#.# eslint-plugin-react@^#.#.# -g
Standard標準,它是一些前端工程師自定的標準。
執行安裝:
npm install eslint-config-standard eslint-plugin-standard eslint-plugin-promise -g
目前來看,公認的最好的標準是Airbnb標準。建議全局安裝這些標準,而後在你的.eslint配置文件中直接使用:
{ "extends": "Airbnb/standard/Google/" }