JavaScript libraries
Summary
Introduction to JavaScript libraries
Overview
JavaScript is arguably the most widely used computer language in the world. The use cases where JavaScript has shown to be replacing traditional platforms are ever increasing. As the scope of the usage grows, it becomes extremely important that a method of distribution of code is used, to not only bring simplicity in further development but also allow reuse of code by the masses. JavaScript libraries solve this problem really well, and there are dozens if not hundreds of libraries available that cater to various use cases.
These various libraries provide pre-written JavaScript code which makes common or complex tasks easy to do. JavaScript libraries often target specific tasks such as DOM manipulation, framework setup and AJAX handling.
Benefits
- Uniform interface for cross-browser compatible code - While modern browsers are becoming increasingly similar in their implementations of the language features and DOM, numerous minor differences still exist. The problem becomes substantial when compatibility with older browsers is required. Quite a few JavaScript libraries try to reduce the boilerplate code that developers have to write to address this issue. They provide a uniform API for development, which all compatibility handling throw browser and feature detection is handled in the background. 
- Higher levels of abstraction - Quite often it is the case that development requires implementations of features that are quite popular in the industry. Auto-completion, AJAX handling, graphics and user interface elements are some examples of areas where libraries can be a big boon. Most efforts can then be focused on customization. 
- Frameworks - While the language itself is quite powerful and yet extremely easy to use, developing and maintaining large code bases can become challenging. There are various frameworks available as JavaScript libraries that implement designs like MVC for writing the code in a more structured fashion. 
Getting started
The most commonly used libraries have rich communities and forums where you can find help to get started with that particular library. JavaScript libraries are often downloaded from the library developer site. Many library developers provide both development and production versions of their libraries. The development versions contain non-minified code which often include comments and hints whereas the production versions often are minified and compressed for live site use.
Optionally, many libraries are available from content delivery networks (CDN) such as cdnjs, Google Hosted Libraries, jsDelivr and Microsoft Ajax Content Delivery Network. You can find more of these and comparisons between them at cdnperf.
Usage
To include a library in your application you simply add a <script> element to your <head> element with the src attribute referencing the URL or path to the library’s source. Below, you see two examples on how to load the jQuery library, one from jsDelivr and one from a local path.
Examples
From CDN (jsDelivr):
<script src="//cdn.jsdelivr.net/jquery/2.1.3/jquery.min.js"></script>
From a local path:
<script src="js/lib/jquery.min.js"></script>
Common libraries
This list showcases JavaScript libraries. They’re sorted alphabetically. If you don’t see yours, please add it to the list.
| Library | Type | Description | 
|---|---|---|
| ajile | Modules | ajile is an open-source browser module that enables namespacing, dependency-management, and on-demand loading of cross-domain, local, and inline scripts. | 
| AngularJS | Framework | AngularJS is a tool set for building the framework most suited to your application development. It is fully extensible and works well with other libraries. Every feature can be modified or replaced to suit your unique development workflow and feature needs. | 
| Backbone | Framework | Backbone.js gives structure to web applications by providing models with key-value binding and custom events, collections with a rich API of enumerable functions, views with declarative event handling, and connects it all to your existing API over a RESTful JSON interface. | 
| FabricJS | Graphics | Fabric is a powerful graphics library that makes working with HTML5 canvas a breeze. It provides a missing object model for canvas, as well as an SVG parser, layer of interactivity, event system, and a whole suite of other indispensable tools (text abstractions, gradients and patterns, image filters, flipping, clipping, animation, free drawing, canvas serialization, and more). | 
| EaselJS | Graphics | EaselJS provides straight forward solutions for working with rich graphics and interactivity with HTML5 Canvas. It provides an API that is familiar to Flash developers, but embraces JavaScript sensibilities. It consists of a full, hierarchical display list, a core interaction model, and helper classes to make working with Canvas much easier. | 
| EmberJS | Framework | Ember is a JavaScript framework for creating ambitious web applications that eliminates boilerplate and provides a standard application architecture. | 
| Ext JS | Framework | Ext JS is a JavaScript framework for creating business application interfaces, it provides an MVC-style application architecture, a set of standard UI widgets such as grids and trees, a theming and templating system, a charting and drawing library and other utilities for creating rich data-oriented applications. | 
| GLGE | Graphics | GLGE is a javascript library intended to ease the use of WebGL. It’s aim is to mask the involved nature of WebGL from the web developer. | 
| jQuery | Tools and Utilites | jQuery is a fast and concise JavaScript Library that simplifies HTML document traversing, event handling, animating, and Ajax interactions for rapid web development. jQuery is designed to change the way that you write JavaScript. | 
| Meteor | Complete Stack | Meteor is a full-stack web application development environment. It runs on Node.js and functionalities can be extended by modules called Meteorites. | 
| Prototype | Framework & Utilities | Prototype is a JavaScript Framework that aims to ease development of dynamic web applications. Featuring a unique, easy-to-use tool kit for class-driven development and the nicest Ajax library around, Prototype is quickly becoming the code base of choice for web application developers everywhere. | 
| Raphaël | Vector Graphics | Raphaël is a small JavaScript library that should simplify development work with vector graphics on the web. If someone wants to create their own specific chart or image crop and rotate widget, for example, they can achieve it simply and easily with this library. | 
| SproutCore | Framework | SproutCore is an open-source JavaScript framework. Its goal is to allow developers to create web applications with advanced capabilities and a user experience comparable to that of desktop applications. | 
| Underscore | Framework | Underscore is a utility-belt library for JavaScript that provides a lot of the functional programming support that you would expect in Prototype.js (or Ruby), but without extending any of the built-in JavaScript objects. It’s the tie to go along with jQuery’s tux, and Backbone.js’s suspenders. | 
| YUI Library | JS/CSS Framework | YUI is a free, open source JavaScript and CSS library for building richly interactive web applications. The YUI Project is a two-way open-source project managed by the YUI engineering team at Yahoo!. |