JSLint,JSHint,ESLint的區別

主流的JS Lint工具及介紹

JavaScript已經發展蠻長時間了,對應的Lint工具也是層出不窮,下面介紹一下比較主流的幾個Lint工具(其實是我用過的幾個XD)

JSLint

JSLint是由Douglas Crockford開發的,可能是最早的JavaScript Lint工具了吧,它的名字來源於著名的C語言工具Lint。老道把他認爲的非Good Parts的部分都報了warning,而且在它的文檔中也提到了你應該欣然接受所有的JSLint的建議。最近看了下,老道還在持續更新着這個項目,而且官網上也有着一個在線的體驗工具,可以嘗試一下。對了,如果想要使用這個工具,建議看看老道在YouTube上關於JavaScript編程風格的視頻,講的還是很幽默的。

JSHint

JSHint是由Anton Kovalyov基於JSLint的代碼實現的開源項目,由於JSLint時期大多數人都在受JSLint壓迫,JSHint相比較之下,更友好,也更容易配置,所以很快就發展了起來,也得到了衆多IDE和編輯器的支持。但是,由於它是基於JSLint開發的,自然原有的一些問題它也繼承下來了,比如不易擴展,不容易直接根據報錯定位到具體的規則配置等,雖然之前好像是有過相關的討論,但是現在仍然沒有什麼好的解決辦法。好在它發展的不錯,很多時候遇到的問題都可以在網上找到相關的解決方案,而且文檔也是非常不錯的。

ESLint

ESLint是由Nicholas C. Zakas在2013年開始開發的,它的初衷就是爲了能讓開發者能自定義自己的linting rules,而且它提供了一套相當完善的插件機制,可以自由的擴展,動態加載配置規則,同時可以方便的根據報錯定位到具體的規則配置。而且我比較喜歡它的一點是文檔非常詳細,可能這也是靈活所必須的吧。在這裏還要提一點,ESLint最初並不是爲了造一個重複的輪子,而是作者在實際使用中的需求沒有能得到JSHint團隊的迴應,所以他就結合當時的JSHint和另一個代碼風格的檢查工具JSCS寫出來了現在具備代碼風格檢查自定義插件擴展功能的ESLint了。

JSLint,JSHint和ESLint的對比

這三個工具各有特色,我只是做一下對比,選擇的話,看個人需求就好了。

JSLint

優點

  • 配置是老道已經定好的,開箱即用。

不足

  • 有限的配置選項,很多規則不能禁用
  • 規範嚴格,凡是不符合老道所認爲的好的風格的,都會有警告(這一項就看你是否完全認同老道了)
  • 擴展性差
  • 無法根據錯誤定位到對應的規則

JSHint

優點

  • 有了很多參數可以配置
  • 支持配置文件,方便使用
  • 支持了一些常用類庫
  • 支持了基本的ES6

不足

  • 不支持自定義規則
  • 無法根據錯誤定位到對應的規則

ESLint

優點

  • 默認規則裏面包含了JSLintJSHint的規則,易於遷移(這肯定是故意的XD)
  • 可配置爲警告錯誤兩個等級,或者直接禁用掉
  • 支持插件擴展
  • 可以自定義規則
  • 可以根據錯誤定位到對應的規則
  • 支持ES6
  • 唯一一個支持JSX的工具

不足

  • 需要進行一些自定義配置(因爲太靈活了嘛,不過文檔是很詳細的)
  •  (它比其他兩個都要慢)
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章