标签: js,前端

js 开发工具

JavaScript 开发工具大全

为了保证可读性,本文采用意译而非直译。另外,本文版权归原作者所有,翻译仅用于学习

简介

2017 年 1 月,Stack Overflow 年度开发者调研一共访问了64000个程序员,发现 JavaScript 已经连续 5 年成为最流行的编程语言。

JavaScript开发工具大全

这篇博客将介绍一些常用的 JavaScript 开发工具:

  • 构建&自动化
  • IDE&编辑器
  • 文档
  • 测试
  • 调试
  • 安全
  • 代码优化&分析
  • 包管理

构建 & 自动化

  • Webpack对 JavaScript 应用依赖的所有模块进行静态分析,生成依赖图,然后将它们打包成数个静态文件。
  • Grunt以将重复耗时的任务自动化。Grunt 的生态系统非常大,有超过 6010 个插件。
  • Gulp发布于 Grunt 之后,采用了完全不同的方式,使用 JavaScript 函数定义任务。它有超过 2770 个插件,并且提供了更好的控制。
  • Browserify使得开发者可以在浏览器使用CommonJS 模块。开发者像在 node 环境一样,通过require('modules')来组织模块之间的引用和依赖,Browserify 将这些依赖打包成浏览器可以直接引用的 JS 文件。
  • Brunch非常简单,速度很快。Brunch 的配置文件非常简单,入门文档非常详细。Brunch 会自动生成 Source Map,方便了开发者 Debug。
  • Yeoman可以用于任何编程语言(JavaScript, Python, C#, Java, etc.)。它是前端开发的脚手架,有 6213 个插件。

IDE & 编辑器

  • WebStorm是一款强大的 JavaScript IDE。它支持多种框架和 CSS 语言,包括前端,后端,移动端以及桌面应用。WebStorm 可以无缝整合第三方工具,例如构建构建、语法检查构建 linter 等等。它提供了代码补全,实时错误监测,导航,内置控制台,各种插件等一系统功能。
  • Atom是 GitHub 团队开发的。开发者可以很容易地对 Atom 进行自定义。Atom 自带了一个包管理工具,代码补全,文件系统浏览器,支持多个平台以及其他有用的功能。
  • Visual Studio Code是微软开发的 IDE,支持 TypeScript。它提供了代码补全,语法高亮,支持 Git 命令等等。另外,它还有非常多的插件。
  • Brackets是一个轻量级的开源编辑器。它专注于可视化工具,可以帮助开发者开发 Web 应用。Brackets 支持实时预览以及行内编辑。

文档

  • Swagger提供了一系列规则用于描述 API。使用 Swagger,可以创建清晰的文档,并且自动化 API 相关的操作(例如功能测试)。
  • JSDoc可以根据 javascript 文件中注释信息,生成 JavaScript 应用程序或库、模块的 API 文档。JSDoc 可以用于管理大型项目。
  • **jGrouseDoc **是一个开源工具,可根据 JavaScript 注释生成类似 Jaavdoc 的源码文档。它不仅可以为变量和函数生成文档,还可以为模块等其他元素生成文档。
  • YUIDoc基于 Nodejs,可以将文档中的注释生成 API 文档。它使用类似于 Javadoc 与 Doxygen 的语法,并且支持实时预览,支持各种语言,并且支持标记语言。
  • **Docco **是免费的文档工具,由 Literate CoffeeScript 编写。它将代码中的注释生成 HTML 文档。Docco 并不限于 JavaScript,同时支持 Python, Ruby, Clojure 等语言。

测试

  • Jasmine是一个行为驱动开发(BDD)框架,用于测试 JavaScript 代码。它不依赖任何第三方模块,也不需要 DOM。它的语法非常简单易懂,使得编写测试变得很简单。另外,它也可以用于测试 Node.js,Python 以及 Ruby。
  • Mocha是一个功能测试框架,用于测试 Node.js 以及浏览器端 JavaScript。作为开发者首选的测试框架,它可以自由的编写测试组,提供详细的测试报告,同时让异步测试非常简单。Mocha 通常与断言库Chai来验证测试结果。
  • PhantomJS用于前端单元测试。由于 PhantomJS 是一个无界面的 Webkit 浏览器引擎,与直接使用浏览器测试相比,使用 PhantomJS 脚本可以运行得更快。它支持各种网页标准,例如 JSON, Canvas, DOM 操作, SVG 以及 CSS 选择器。
  • Protractor是一个端到端测试框架,用于测试 Angular 应用。它是基于 WebDriverJS 构建的,它可以通过浏览器事件或者原生事件,从而模拟真实用户,来测试应用。

调试

  • JavaScript Debugger由 Mozilla Developer Network (MDN)开发,可以独立用于调试 Node.js 代码,或者用于其他浏览器。Firefox 提供了本地和远程调试功能,并且,Firefox 安卓端也用于调试运行在安卓应用。
  • Chrome Dev Tools提供了一系列工具,可以用于调试 JavaScript 代码,编辑 CSS,以及测试应用性能。
  • ng-inspector是 Firefox,Chrome 和 Safari 浏览器插件,可以帮助开发者开发、理解以及调试 AngularJS 应用。它提供了实时更新,DOM 高亮等功能。
  • Augury是一个 Chrome 插件,可以用于调试 Angular 2 应用。它让开发者可以直接查看应用结构,操作特征以及状态变化。

安全

  • Snyk是一个付费服务,用于发现、修复和预防 JavaScript,Node.js 和 Ruby 应用的已知漏洞。Snyk 拥有自己的漏洞库,以及 NSP 和 NIST NVD 的漏洞数据。它允许开发者使用它们的补丁和更新来修复这些安全漏洞。
  • Node Security Project提供了工具用于扫描依赖来监测漏洞。NSP 使用自己的漏洞数据,以及来自 NIST NVD 的漏洞数据。NSP 支持集成 GitHub 和 CI 软件,实时监测和报警,并且可以提供如何修复 Node.js 应用漏洞的建议。
  • RetireJS是一个开源的依赖监测工具。它包含了多个组件,包括命令行工具,Grunt 插件,Firefox 和 Chrome 插件,Burp 和 OWASP ZAP 插件。Retirejs 从 NIST NVD,漏洞追踪系统,博客和邮件列表等手机漏洞数据。
  • Gemnasium是一个付费工具,不过有免费方案。它支持各种技术,比如 Ruby, PHP, Bower, Python 和 npm。Gemnasium 提供很多非常有用的特性,比如自动更新,实时报警以及 Slack 集成等。
  • OSSIndex支持多个生态系统(Java, JavaScript 和.NET/C#),以及多个平台,例如 NuGet, npm, Bower, Chocolatey, Maven, Composer, Drupal 和 MSI。它从 NVD 以及其他来源收集漏洞数据。

代码优化 & 分析

  • JSLint是一个 Web 服务,用于验证 JavaScript 的代码质量。当它诊断到一个问题时,它会返回问题的大致位置和出错信息。JSLint 可以分析一些编码规范以及语法错误。
  • JSHint可以发现 JavaScript 中的错误以及一些潜在的问题。JSHint 是一个静态代码分析工具,旨在帮助开发者编写大型的程序。它可以诊断语法错误、隐形类型转换等问题,但是它并不能确定你的应用是否正确、性能是否足够好、以及是否会发生内存泄漏。 JSHint 是 JSLint 的一个 fork。
  • ESLint是一个开源诊断工具,用于 JSX 和 JavaScript 应用。它可以帮助开发者发现可疑的或者不符合特定编程规范的代码。它帮助开发者在没有执行代码之前发现 JS 代码中问题,节省了不少时间。ESLint 由 Node.js 编写,可以使用 NPM 安装。
  • Flow是 JavaScript 代码静态类型检测器,由 Facebook 开发。Flow 可以在编码时检查到类型错误并做出提示。

包管理

  • Bower是一个用于管理前端依赖的包管理器,Twitter 创建。它提供了大量可供使用的依赖包,帮助 JavaScript 开发者更方便地管理前端依赖的 JS 库。
  • NPMnode package manager的缩写,事实上 NPM 包可以用于前后端。它是 JavaScript 包管理系统,也是世界上最大的依赖库,有超过 475,000 个模块。
  • Yarn是 Facebook, Google, Exponent 和 Tilde 开发的一款新的 JavaScript 包管理工具。与 NPM 相比,它解决了安全、性能以及一致性问题。
  • Duo吸取了 Component, Browserify 和 Go 的经验,致力于简化大型 Web 应用的构建过程。

原文: THE ULTIMATE LIST OF JAVASCRIPT TOOLS

译者: Fundebug