2016-02-06 02:27:06 -05:00
include ../_util-fns
2016-02-17 22:31:42 -05:00
:marked
2016-08-29 11:37:39 -04:00
Angular applications and Angular itself depend upon features and functionality provided by a variety of third-party packages.
2016-04-27 14:28:22 -04:00
These packages are maintained and installed with the Node Package Manager (<a href="https://docs.npmjs.com/" target="_blank">npm</a>).
2016-02-17 22:31:42 -05:00
.l-sub-section
:marked
2017-03-08 16:30:50 -05:00
Node.js and npm are essential to Angular development.
2016-05-21 12:36:27 -04:00
<a href="https://docs.npmjs.com/getting-started/installing-node" target="_blank" title="Installing Node.js and updating npm">
2016-08-29 11:37:39 -04:00
Get them now</a> if they're not already installed on your machine.
2017-03-08 16:30:50 -05:00
2016-08-29 11:37:39 -04:00
**Verify that you are running node `v4.x.x` or higher and npm `3.x.x` or higher**
by running the commands `node -v` and `npm -v` in a terminal/console window.
2016-05-28 16:49:13 -04:00
Older versions produce errors.
2016-05-21 12:36:27 -04:00
2017-03-08 16:30:50 -05:00
Consider using [nvm](https://github.com/creationix/nvm) for managing multiple
versions of node and npm. You may need [nvm](https://github.com/creationix/nvm) if
you already have projects running on your machine that use other versions of node and npm.
2016-05-21 12:36:27 -04:00
2016-02-17 22:31:42 -05:00
:marked
2017-03-08 16:30:50 -05:00
During [Setup](setup.html), a <a href="https://docs.npmjs.com/files/package.json" target="_blank">package.json</a>
file is installed with a comprehensive starter set of
packages as specified in the `dependencies` and `devDependencies` sections.
You can use other packages but the packages in _this particular set_ work well together and include
everything you need to build and run the sample applications in this series.
2016-04-27 14:28:22 -04:00
.l-sub-section
:marked
2016-08-29 11:37:39 -04:00
Note: A cookbook or guide page may require an additional library such as *jQuery*.
2016-04-27 14:28:22 -04:00
:marked
2017-03-08 16:30:50 -05:00
You'll install more than you need for the QuickStart guide.
No worries!
2016-08-29 11:37:39 -04:00
You only serve to the client those packages that the application actually requests.
2017-03-08 16:30:50 -05:00
2016-08-29 11:37:39 -04:00
This page explains what each package does. You can make substitutions later to suit your tastes and experience.
2017-03-08 16:30:50 -05:00
2016-02-17 22:31:42 -05:00
.l-main-section
:marked
## *dependencies* and *devDependencies*
2017-03-08 16:30:50 -05:00
The `package.json` includes two sets of packages,
2016-02-17 22:31:42 -05:00
[dependencies](#dependencies) and [devDependencies](#dev-dependencies).
2017-03-08 16:30:50 -05:00
The *dependencies* are essential to *running* the application.
The *devDependencies* are only necessary to *develop* the application.
2016-08-29 11:37:39 -04:00
You can exclude them from production installations by adding `--production` to the install command, as follows:
2016-02-17 22:31:42 -05:00
code-example(format="." language="bash").
npm install my-application --production
2017-03-08 16:30:50 -05:00
2016-02-17 22:31:42 -05:00
a(id="dependencies")
.l-main-section
:marked
## *dependencies*
2016-08-29 11:37:39 -04:00
The `dependencies` section of `package.json` contains:
2017-03-08 16:30:50 -05:00
* ***Features***: Feature packages give the application framework and utility capabilities.
* ***Polyfills***: Polyfills plug gaps in the browser's JavaScript implementation.
* ***Other***: Other libraries that support the application such as `bootstrap` for HTML widgets and styling.
2016-02-17 22:31:42 -05:00
.l-main-section
:marked
### Feature Packages
2017-03-08 16:30:50 -05:00
***@angular/core***: Critical runtime parts of the framework needed by every application.
2016-04-27 14:28:22 -04:00
Includes all metadata decorators, `Component`, `Directive`, dependency injection, and the component lifecycle hooks.
2017-03-08 16:30:50 -05:00
***@angular/common***: The commonly needed services, pipes, and directives provided by the Angular team.
***@angular/compiler***: Angular's *Template Compiler*.
It understands templates and can convert them to code that makes the application run and render.
2016-08-29 11:37:39 -04:00
Typically you don’ t interact with the compiler directly; rather, you use it indirectly via `platform-browser-dynamic` or the offline template compiler.
2017-03-08 16:30:50 -05:00
***@angular/platform-browser***: Everything DOM and browser related, especially
the pieces that help render into the DOM.
This package also includes the `bootstrapStatic()` method
for bootstrapping applications for production builds that pre-compile templates offline.
***@angular/platform-browser-dynamic***: Includes [Providers](../api/core/index/Provider-type-alias.html)
and a [bootstrap](ngmodule.html#bootstrap) method for applications that
2016-07-21 14:00:36 -04:00
compile templates on the client. Don’ t use offline compilation.
2016-08-29 11:37:39 -04:00
Use this package for bootstrapping during development and for bootstrapping plunker samples.
2017-03-08 16:30:50 -05:00
***@angular/http***: Angular's HTTP client.
***@angular/router***: Component router.
***@angular/upgrade***: Set of utilities for upgrading AngularJS applications to Angular.
***[system.js](https://github.com/systemjs/systemjs)***: A dynamic module loader compatible with the
2016-02-17 22:31:42 -05:00
[ES2015 module](http://www.2ality.com/2014/09/es6-modules-final.html) specification.
2016-08-29 11:37:39 -04:00
Other viable choices include the well-regarded [webpack](https://webpack.github.io/).
2017-03-08 16:30:50 -05:00
2016-08-29 11:37:39 -04:00
Your future applications are likely to require additional packages that provide
2016-02-17 22:31:42 -05:00
HTML controls, themes, data access, and various utilities.
2017-03-08 16:30:50 -05:00
2016-02-17 22:31:42 -05:00
a(id="polyfills")
.l-main-section
:marked
2016-08-29 11:37:39 -04:00
### Polyfill packages
2017-03-08 16:30:50 -05:00
2016-02-17 22:31:42 -05:00
Angular requires certain [polyfills](https://en.wikipedia.org/wiki/Polyfill) in the application environment.
2016-08-29 11:37:39 -04:00
Install these polyfills using the npm packages that Angular lists in the *peerDependencies* section of its `package.json`.
2017-03-08 16:30:50 -05:00
2016-08-29 11:37:39 -04:00
You must list these packages in the `dependencies` section of your own `package.json`.
2017-03-08 16:30:50 -05:00
2016-02-17 22:31:42 -05:00
.l-sub-section
:marked
2016-08-29 11:37:39 -04:00
For background on this requirement, see [Why peerDependencies?](#why-peer-dependencies).
2016-02-17 22:31:42 -05:00
:marked
2017-03-08 16:30:50 -05:00
***core-js***: Patches the global context (window) with essential features of ES2015 (ES6).
You may substitute an alternative polyfill that provides the same core APIs.
2016-08-29 11:37:39 -04:00
When these APIs are implemented by the major browsers, this dependency will become unnecessary.
2017-03-08 16:30:50 -05:00
***rxjs***: A polyfill for the [Observables specification](https://github.com/zenparsing/es-observable) currently before the
2016-02-17 22:31:42 -05:00
[TC39](http://www.ecma-international.org/memento/TC39.htm) committee that determines standards for the JavaScript language.
2017-03-08 16:30:50 -05:00
You can pick a preferred version of *rxjs* (within a compatible version range)
2016-02-17 22:31:42 -05:00
without waiting for Angular updates.
2017-03-08 16:30:50 -05:00
***zone.js***: A polyfill for the [Zone specification](https://gist.github.com/mhevery/63fdcdf7c65886051d55) currently before the
2016-02-17 22:31:42 -05:00
[TC39](http://www.ecma-international.org/memento/TC39.htm) committee that determines standards for the JavaScript language.
2017-03-08 16:30:50 -05:00
You can pick a preferred version of *zone.js* to use (within a compatible version range)
2016-02-17 22:31:42 -05:00
without waiting for Angular updates.
2016-04-27 14:28:22 -04:00
a(id="other")
.l-main-section
:marked
### Other helper libraries
2017-03-08 16:30:50 -05:00
***angular-in-memory-web-api***: An Angular-supported library that simulates a remote server's web api
without requiring an actual server or real HTTP calls.
Good for demos, samples, and early stage development (before you even have a server).
Read about it in the [HTTP Client](server-communication.html#in-mem-web-api) page.
***bootstrap***: [Bootstrap](http://getbootstrap.com/) is a popular HTML and CSS framework for designing responsive web apps.
2016-08-29 11:37:39 -04:00
Some of the samples improve their appearance with *bootstrap*.
2017-03-08 16:30:50 -05:00
2016-02-17 22:31:42 -05:00
a(id="dev-dependencies")
.l-main-section
:marked
## *devDependencies*
2016-08-29 11:37:39 -04:00
The packages listed in the *devDependencies* section of the `package.json` help you develop the application.
You don't have to deploy them with the production application although there is no harm in doing so.
2016-02-17 22:31:42 -05:00
2017-03-08 16:30:50 -05:00
***[concurrently](https://www.npmjs.com/package/concurrently)***:
2016-07-21 14:00:36 -04:00
A utility to run multiple *npm* commands concurrently on OS/X, Windows, and Linux operating systems.
2017-03-08 16:30:50 -05:00
***[lite-server](https://www.npmjs.com/package/lite-server)***:
A light-weight, static file server, by [John Papa](http://johnpapa.net/)
2016-02-17 22:31:42 -05:00
with excellent support for Angular apps that use routing.
2017-03-08 16:30:50 -05:00
***[typescript](https://www.npmjs.com/package/typescript)***:
2016-10-20 20:01:16 -04:00
the TypeScript language server, including the *tsc* TypeScript compiler.
2017-03-08 16:30:50 -05:00
***@types/\****: TypeScript definition files.
Learn more about it in the [TypeScript Configuration](typescript-configuration.html#typings) guide.
2016-02-17 22:31:42 -05:00
.l-main-section
a(id="why-peer-dependencies")
:marked
## Why *peerDependencies*?
2017-03-08 16:30:50 -05:00
There isn't a [*peerDependencies*](https://nodejs.org/en/blog/npm/peer-dependencies/) section in the QuickStart `package.json`.
But Angular has a *peerDependencies* section in
*its* `package.json`, which has important consequences for your application.
This section explains why you load the [polyfill](#polyfills) *dependency*
packages in the QuickStart application's `package.json`,
2016-08-29 11:37:39 -04:00
and why you'll need those packages in your own applications.
2017-03-08 16:30:50 -05:00
2016-08-29 11:37:39 -04:00
Packages depend on other packages. For example, your application depends on the Angular package.
2017-03-08 16:30:50 -05:00
Two packages, "A" and "B", could depend on the same third package "C".
2016-08-29 11:37:39 -04:00
"A" and "B" might both list "C" among their *dependencies*.
2017-03-08 16:30:50 -05:00
What if "A" and "B" depend on different versions of "C" ("C1" and "C2"). The npm package system supports that.
2016-08-29 11:37:39 -04:00
It installs "C1" in the `node_modules` folder for "A" and "C2" in the `node_modules` folder for "B".
Now "A" and "B" have their own copies of "C" and they run without interferring with one another.
2017-03-08 16:30:50 -05:00
2016-08-29 11:37:39 -04:00
But there is a problem. Package "A" may require the presence of "C1" without actually calling upon it directly.
"A" may only work if *everyone is using "C1"*. It falls down if any part of the application relies on "C2".
2017-03-08 16:30:50 -05:00
2016-08-29 11:37:39 -04:00
The solution is for "A" to declare that "C1" is a *peer dependency*.
2017-03-08 16:30:50 -05:00
2016-02-17 22:31:42 -05:00
The difference between a `dependency` and a `peerDependency` is roughly this:
2017-03-08 16:30:50 -05:00
2016-02-17 22:31:42 -05:00
>A **dependency** says, "I need this thing directly available to *me*."
>
2016-08-29 11:37:39 -04:00
>A **peerDependency** says, "If you want to use me, you need this thing available to *you*."
2017-03-08 16:30:50 -05:00
The Angular `package.json` specifies several *peer dependency* packages,
2016-02-17 22:31:42 -05:00
each pinned to a particular version of a third-party package.
2017-03-08 16:30:50 -05:00
### You must install Angular's *peerDependencies* yourself.
2016-08-29 11:37:39 -04:00
When *npm* installs packages listed in *your* `dependencies` section,
2016-02-17 22:31:42 -05:00
it also installs the packages listed within *their* packages `dependencies` sections.
The process is recursive.
2017-03-08 16:30:50 -05:00
2016-08-29 11:37:39 -04:00
However, as of version 3, *npm* does *not* install packages listed in *peerDependencies* sections.
2017-03-08 16:30:50 -05:00
2016-08-29 11:37:39 -04:00
This means that when your application installs Angular, ***npm* doesn't automatically install
2016-02-17 22:31:42 -05:00
the packages listed in Angular's *peerDependencies* section**.
2017-03-08 16:30:50 -05:00
2016-08-29 11:37:39 -04:00
Fortunately, *npm* issues a warning (a) When any *peer dependencies* are missing, or (b)
When the application or any of its other dependencies
2017-03-08 16:30:50 -05:00
installs a different version of a *peer dependency*.
2016-08-29 11:37:39 -04:00
These warnings guard against accidental failures due to version mismatches.
They leave you in control of package and version resolution.
2017-03-08 16:30:50 -05:00
2016-08-29 11:37:39 -04:00
It is your responsibility to list all *peer dependency* packages **among your own *devDependencies***.
2017-03-08 16:30:50 -05:00
2016-02-17 22:31:42 -05:00
.l-sub-section
:marked
#### The future of *peerDependencies*
2017-03-08 16:30:50 -05:00
2016-08-29 11:37:39 -04:00
The Angular polyfill dependencies are hard requirements. Currently, there is no way to make them optional.
2017-03-08 16:30:50 -05:00
However, there is an npm feature request for "optional peerDependencies," which would allow you to model this relationship better.
2016-08-29 11:37:39 -04:00
When this feature request is implemented, Angular will switch from *peerDependencies* to *optionalPeerDependencies* for all polyfills.