ESLint は、JavaScript コードに存在する問題を発見するための静的コード解析用ツールである。2013 年に、Nicholas C. Zakas により作成された。[2][3] ESLintの設定はユーザーが設定することができ、またユーザーはカスタマイズされたルールを利用できる。ESLintは、コードの品質 及び コーディングスタイル 両方の問題を検知することができる。 ESLint は現在のJavaScriptの標準であるECMAScriptの構文や、将来的に追加される可能性がある試験的な構文もサポートしている。プラグインやトランスパイラを使用することによって、JSX やTypeScript の解析も可能になる。[4][5]

ESLint
作者 Nicholas C. Zakas
開発元 Nicholas C. Zakas
初版 2013年6月30日 (11年前) (2013-06-30)
最新版
9.17.0[1] ウィキデータを編集 / 13 12月 2024
リポジトリ ウィキデータを編集
プログラミング
言語
JavaScript
対応OS Cross-platform
対応言語 英語
種別 静的コード解析
ライセンス MIT License
公式サイト eslint.org
テンプレートを表示

歴史

編集

JSLintJSHint は、コードの品質コーディングスタイルに関するルールを追加することができなかった。[3] そのため、ZakasはJSHintにコントリビュートするのではなく、2013年6月に新しいコード解析としてESLint (当時はJSCheckという名称だったが、1ヶ月後に名称を変更した)を作成することを決めた。ESLintはこれらのツールとは違い、実行時に動的にルールを変更したり追加したりできるようにした。[6][7]

2016年4月に、 ESLint は jQuery Foundationに加入した。[8] その同年、jQuery Foundation は Dojo Foundation とともにLinux Foundationの一部となり、JS Foundation のプロジェクトとして成立した。 [9][10][11]

2017年10月に、JS Foundationのメンターシッププログラムを卒業した。[12]

2019年3月現在、JS Foundation と Node.js Foundationの合併により、ESLintは OpenJS Foundationのプロジェクトの一部である。[13][14]

採用

編集

JetBrains は、WebStormコードエディター内で、ESLintをサポートしている。これにより、編集中のファイルにESLintが実行され、エディタ内で問題のあるコードの近くに警告が表示される。[15][16][17]

2016年から、 Vue.js は、Vue.jsの構文を自動的に検証する目的のESLintプラグインを提供している。[18][19][20] 2018年からは、新しいVue.jsプロジェクトを作成するときのウィザード 内で、このプラグインの使用を推奨している。[21]

2018年10月に、Facebookが開発している React は、公式のESLintプラグインを公開した。[22][23]

2021年現在、ESLintは最も使われているJavaScript用リンターであり、週に14,000,000回以上ダウンロードされている。 [24]

脚注

編集
  1. ^ Release 9.17.0” (13 12月 2024). 23 12月 2024閲覧。
  2. ^ First commit - eslint/eslint” (英語). GitHub. 2019年7月5日閲覧。
  3. ^ a b Zakas (16 July 2013). “Introducing ESLint” (英語). nczonline.net. 2018年2月26日閲覧。 “JSLint was the state of the art in JavaScript linting technology”
  4. ^ The future of TypeScript on ESLint” (英語). ESLint - Pluggable JavaScript linter. 2020年4月24日閲覧。
  5. ^ Accessibility auditing with eslint-plugin-jsx-a11y” (英語). web.dev. Google Developers (2019年4月29日). 2020年4月24日閲覧。 “The [ELint plugin] can help pinpoint [issues] in your JSX.”
  6. ^ “Understanding the Real Advantages of Using ESLint”. Rangle.io Blog. (2015年3月26日). http://blog.rangle.io/understanding-the-real-advantages-of-using-eslint/ 2018年2月26日閲覧。 
  7. ^ Rename project to ESLint · eslint/eslint@4f4c351” (英語). GitHub (4 July 2013). 2020年6月26日閲覧。
  8. ^ Zakas (19 April 2016). “ESLint Joins The jQuery Foundation” (英語). eslint.org. 2019年7月5日閲覧。
  9. ^ jQuery Foundation and Dojo Foundation to Merge” (英語). Official jQuery Blog (1 September 2015). 2018年7月2日閲覧。
  10. ^ “jQuery Foundation and Dojo Foundation to Merge”. PRWeb. (1 July 2015). http://www.prweb.com/releases/2015/08/prweb12931885.htm 2018年7月2日閲覧。 
  11. ^ “Announcing the JS Foundation!” (英語). SitePen. (2016年10月17日). https://www.sitepen.com/blog/2016/10/17/announcing-the-js-foundation/ 2018年7月2日閲覧。 
  12. ^ “ESLint Graduates from JS Foundation Mentorship Program” (英語). JS Foundation Blog. (2017年10月5日). https://js.foundation/announcements/2017/10/05/eslint-graduates-from-js-foundation-mentorship-program 2019年7月5日閲覧。 
  13. ^ Singh, Manish (2019年3月12日). “Node.js and JS foundations are merging to form OpenJS”. VentureBeat. https://venturebeat.com/2019/03/12/node-js-and-js-foundations-are-merging-to-form-openjs/ 2019年3月21日閲覧。 
  14. ^ “The Node.js Foundation and JS Foundation Announce an Intent to Merge” (英語). JS Foundation Blog. (2018年10月4日). https://js.foundation/announcements/2018/10/04/the-node-js-foundation-and-js-foundation-announce-an-intent-to-merge-a-message-from-the-boards-and-a-faq-around-the-announcement 2019年7月5日閲覧. "How will this impact the technical direction of … ESLint This will not change the technical independence for projects like ESLint." 
  15. ^ WebStorm Linting, refactoring and compiling” (英語). WebStorm Blog. JetBrains (30 December 2015). 2019年7月5日閲覧。
  16. ^ Using JavaScript Standard Style” (英語). WebStorm Blog. JetBrains (7 April 2017). 2019年7月5日閲覧。
  17. ^ ESLint - WebStorm Manual”. JetBrains. 2019年7月5日閲覧。
  18. ^ Writing Vue.js Applications in TypeScript”. Telstra Kloud. 2019年7月5日閲覧。
  19. ^ Lesson: Automatic Linting with ESLint - The Vue.js Master Class” (英語). Vue School. 2019年7月5日閲覧。
  20. ^ Introduction | eslint-plugin-vue”. eslint.vuejs.org. 2019年7月5日閲覧。
  21. ^ The Vue Handbook: a thorough introduction to Vue.js” (英語). Developer News (2018年7月5日). 2019年7月5日閲覧。 “Use the interactive CLI to create a new Vue project [..] By default, there is [..] ESLint integration”
  22. ^ ESLint Plugin – Rules of Hooks – React Manual” (英語). reactjs.org. 2019年7月5日閲覧。
  23. ^ Markbåge (25 October 2018). “Implement the Hooks proposal · facebook/react” (英語). GitHub. 2019年7月5日閲覧。
  24. ^ jslint vs jshint vs eslint vs tslint vs @typescript eslint/eslint plugin” (英語). www.npmtrends.com. 2021年1月26日閲覧。

外部リンク

編集