531 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			531 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
# Browser support
 | 
						|
 | 
						|
Angular supports most recent browsers. This includes the following specific versions:
 | 
						|
 | 
						|
<table>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
<th>
 | 
						|
      Browser
 | 
						|
</th>
 | 
						|
 | 
						|
<th>
 | 
						|
      Supported versions
 | 
						|
</th>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
    <td>
 | 
						|
      Chrome
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      latest
 | 
						|
    </td>
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
    <td>
 | 
						|
      Firefox
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      latest
 | 
						|
    </td>
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
    <td>
 | 
						|
      Edge
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      2 most recent major versions
 | 
						|
    </td>
 | 
						|
  </tr>
 | 
						|
  <tr>
 | 
						|
    <td>
 | 
						|
      IE
 | 
						|
    </td>
 | 
						|
    <td>
 | 
						|
      11, 10, 9 ("compatibility view" mode not supported)
 | 
						|
    </td>
 | 
						|
  </tr>
 | 
						|
 <tr>
 | 
						|
   <tr>
 | 
						|
    <td>
 | 
						|
      IE Mobile
 | 
						|
    </td>
 | 
						|
    <td>
 | 
						|
      11
 | 
						|
    </td>
 | 
						|
  </tr>
 | 
						|
 <tr>
 | 
						|
    <td>
 | 
						|
      Safari
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      2 most recent major versions
 | 
						|
    </td>
 | 
						|
  </tr>
 | 
						|
  <tr>
 | 
						|
    <td>
 | 
						|
      iOS
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      2 most recent major versions
 | 
						|
    </td>
 | 
						|
  </tr>
 | 
						|
  <tr>
 | 
						|
    <td>
 | 
						|
      Android
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      X (10.0), Pie (9.0), Oreo (8.0), Nougat (7.0)
 | 
						|
    </td>
 | 
						|
  </tr>
 | 
						|
 | 
						|
</table>
 | 
						|
 | 
						|
<div class="alert is-helpful">
 | 
						|
 | 
						|
Angular's continuous integration process runs unit tests of the framework on all of these browsers for every pull request,
 | 
						|
using <a href="https://saucelabs.com/">SauceLabs</a> and
 | 
						|
<a href="https://www.browserstack.com">Browserstack</a>.
 | 
						|
 | 
						|
</div>
 | 
						|
 | 
						|
## Polyfills
 | 
						|
 | 
						|
Angular is built on the latest standards of the web platform.
 | 
						|
Targeting such a wide range of browsers is challenging because they do not support all features of modern browsers.
 | 
						|
You compensate by loading polyfill scripts ("polyfills") for the browsers that you must support.
 | 
						|
The [table below](#polyfill-libs) identifies most of the polyfills you might need.
 | 
						|
 | 
						|
<div class="alert is-important">
 | 
						|
 | 
						|
The suggested polyfills are the ones that run full Angular applications.
 | 
						|
You may need additional polyfills to support features not covered by this list.
 | 
						|
Note that polyfills cannot magically transform an old, slow browser into a modern, fast one.
 | 
						|
 | 
						|
</div>
 | 
						|
 | 
						|
In Angular CLI version 8 and higher, applications are built using *differential loading*, a strategy where the CLI builds two separate bundles as part of your deployed application.
 | 
						|
 | 
						|
* The first bundle contains modern ES2015 syntax, takes advantage of built-in support in modern browsers, ships less polyfills, and results in a smaller bundle size.
 | 
						|
 | 
						|
* The second bundle contains code in the old ES5 syntax, along with all necessary polyfills. This results in a larger bundle size, but supports older browsers.
 | 
						|
 | 
						|
This strategy allows you to continue to build your web application to support multiple browsers, but only load the necessary code that the browser needs.
 | 
						|
For more information about how this works, see [Differential Loading](guide/deployment#differential-loading) in the [Deployment guide](guide/deployment).
 | 
						|
 | 
						|
## Enabling polyfills with CLI projects
 | 
						|
 | 
						|
The [Angular CLI](cli) provides support for polyfills.
 | 
						|
If you are not using the CLI to create your projects, see [Polyfill instructions for non-CLI users](#non-cli).
 | 
						|
 | 
						|
When you create a project with the `ng new` command, a `src/polyfills.ts` configuration file is created as part of your project folder.
 | 
						|
This file incorporates the mandatory and many of the optional polyfills as JavaScript `import` statements.
 | 
						|
 | 
						|
* The npm packages for the [_mandatory_ polyfills](#polyfill-libs) (such as `zone.js`) are installed automatically for you when you create your project with `ng new`, and their corresponding `import` statements are already enabled in the `src/polyfills.ts` configuration file.
 | 
						|
 | 
						|
* If you need an _optional_ polyfill, you must install its npm package, then uncomment or create the corresponding import statement in the `src/polyfills.ts` configuration file.
 | 
						|
 | 
						|
For example, if you need the optional [web animations polyfill](http://caniuse.com/#feat=web-animation), you could install it with `npm`, using the following command (or the `yarn` equivalent):
 | 
						|
 | 
						|
<code-example language="sh" class="code-shell">
 | 
						|
  # install the optional web animations polyfill
 | 
						|
  npm install --save web-animations-js
 | 
						|
</code-example>
 | 
						|
 | 
						|
You can then add the import statement in the `src/polyfills.ts` file.
 | 
						|
For many polyfills, you can simply un-comment the corresponding `import` statement in the file, as in the following example.
 | 
						|
 | 
						|
<code-example header="src/polyfills.ts">
 | 
						|
  /**
 | 
						|
  * Required to support Web Animations `@angular/platform-browser/animations`.
 | 
						|
  * Needed for: All but Chrome, Firefox and Opera. http://caniuse.com/#feat=web-animation
 | 
						|
  **/
 | 
						|
  import 'web-animations-js';  // Run `npm install --save web-animations-js`.
 | 
						|
</code-example>
 | 
						|
 | 
						|
If the polyfill you want is not already in `polyfills.ts` file, add the `import` statement by hand.
 | 
						|
 | 
						|
 | 
						|
{@a polyfill-libs}
 | 
						|
 | 
						|
### Mandatory polyfills
 | 
						|
These are the polyfills required to run an Angular application on each supported browser:
 | 
						|
 | 
						|
<table>
 | 
						|
 | 
						|
  <tr style="vertical-align: top">
 | 
						|
 | 
						|
    <th>
 | 
						|
      Browsers (Desktop & Mobile)
 | 
						|
    </th>
 | 
						|
 | 
						|
    <th>
 | 
						|
      Polyfills Required
 | 
						|
    </th>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr style="vertical-align: top">
 | 
						|
 | 
						|
    <td>
 | 
						|
      Chrome, Firefox, Edge, <br>
 | 
						|
      Safari, Android, IE 10+
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      [ES2015](guide/browser-support#core-es6)
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr style="vertical-align: top">
 | 
						|
 | 
						|
    <td>
 | 
						|
      IE 9
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      ES2015<br>[classList](guide/browser-support#classlist)
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
</table>
 | 
						|
 | 
						|
 | 
						|
### Optional browser features to polyfill
 | 
						|
 | 
						|
Some features of Angular may require additional polyfills.
 | 
						|
 | 
						|
<table>
 | 
						|
 | 
						|
  <tr style="vertical-align: top">
 | 
						|
 | 
						|
    <th>
 | 
						|
      Feature
 | 
						|
    </th>
 | 
						|
 | 
						|
    <th>
 | 
						|
      Polyfill
 | 
						|
    </th>
 | 
						|
 | 
						|
    <th style="width: 50%">
 | 
						|
       Browsers (Desktop & Mobile)
 | 
						|
    </th>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr style="vertical-align: top">
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      [AnimationBuilder](api/animations/AnimationBuilder).
 | 
						|
      (Standard animation support does not require polyfills.)
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      [Web Animations](guide/browser-support#web-animations)
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      <p>If AnimationBuilder is used, enables scrubbing
 | 
						|
      support for IE/Edge and Safari.
 | 
						|
      (Chrome and Firefox support this natively).</p>
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr style="vertical-align: top">
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
       [NgClass](api/common/NgClass) on SVG elements
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      [classList](guide/browser-support#classlist)
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      IE 10, IE 11
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr style="vertical-align: top">
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      [Http](guide/http) when sending and receiving binary data
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      [Typed Array](guide/browser-support#typedarray)<br>
 | 
						|
 | 
						|
      [Blob](guide/browser-support#blob)<br>
 | 
						|
 | 
						|
      [FormData](guide/browser-support#formdata)
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      IE 9
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr style="vertical-align: top">
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      [Router](guide/router) when using
 | 
						|
      [hash-based routing](guide/router#appendix-locationstrategy-and-browser-url-styles)
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      [ES7/array](guide/browser-support#core-es7-array)
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      IE 11
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
</table>
 | 
						|
 | 
						|
 | 
						|
 | 
						|
### Suggested polyfills
 | 
						|
 | 
						|
The following polyfills are used to test the framework itself. They are a good starting point for an application.
 | 
						|
 | 
						|
 | 
						|
<table>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
    <th>
 | 
						|
      Polyfill
 | 
						|
    </th>
 | 
						|
 | 
						|
    <th>
 | 
						|
      License
 | 
						|
    </th>
 | 
						|
 | 
						|
    <th>
 | 
						|
      Size*
 | 
						|
    </th>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      <a id='core-es7-array' href="https://github.com/zloirock/core-js/tree/v2/fn/array">ES7/array</a>
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      MIT
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      0.1KB
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      <a id='core-es6' href="https://github.com/zloirock/core-js">ES2015</a>
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      MIT
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      27.4KB
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      <a id='classlist' href="https://github.com/eligrey/classList.js">classList</a>
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      Public domain
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      1KB
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      <a id='intl' href="https://github.com/andyearnshaw/Intl.js">Intl</a>
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      MIT / Unicode license
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      13.5KB
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
       <a id='web-animations' href="https://github.com/web-animations/web-animations-js">Web Animations</a>
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      Apache
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      14.8KB
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
      <a id='typedarray' href="https://github.com/inexorabletash/polyfill/blob/master/typedarray.js">Typed Array</a>
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      MIT
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      4KB
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
       <a id='blob' href="https://github.com/eligrey/Blob.js">Blob</a>
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      MIT
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      1.3KB
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
  <tr>
 | 
						|
 | 
						|
    <td>
 | 
						|
 | 
						|
       <a id='formdata' href="https://github.com/francois2metz/html5-formdata">FormData</a>
 | 
						|
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      MIT
 | 
						|
    </td>
 | 
						|
 | 
						|
    <td>
 | 
						|
      0.4KB
 | 
						|
    </td>
 | 
						|
 | 
						|
  </tr>
 | 
						|
 | 
						|
</table>
 | 
						|
 | 
						|
 | 
						|
\* Figures are for minified and gzipped code,
 | 
						|
computed with the <a href="http://closure-compiler.appspot.com/home">closure compiler</a>.
 | 
						|
 | 
						|
{@a non-cli}
 | 
						|
 | 
						|
## Polyfills for non-CLI users
 | 
						|
 | 
						|
If you are not using the CLI, add your polyfill scripts directly to the host web page (`index.html`).
 | 
						|
 | 
						|
For example:
 | 
						|
 | 
						|
<code-example header="src/index.html" language="html">
 | 
						|
  <!-- pre-zone polyfills -->
 | 
						|
  <script src="node_modules/core-js/client/shim.min.js"></script>
 | 
						|
  <script src="node_modules/web-animations-js/web-animations.min.js"></script>
 | 
						|
  <script>
 | 
						|
    /**
 | 
						|
     * you can configure some zone flags which can disable zone interception for some
 | 
						|
     * asynchronous activities to improve startup performance - use these options only
 | 
						|
     * if you know what you are doing as it could result in hard to trace down bugs..
 | 
						|
     */
 | 
						|
    // __Zone_disable_requestAnimationFrame = true; // disable patch requestAnimationFrame
 | 
						|
    // __Zone_disable_on_property = true; // disable patch onProperty such as onclick
 | 
						|
    // __zone_symbol__UNPATCHED_EVENTS = ['scroll', 'mousemove']; // disable patch specified eventNames
 | 
						|
 | 
						|
    /*
 | 
						|
     * in IE/Edge developer tools, the addEventListener will also be wrapped by zone.js
 | 
						|
     * with the following flag, it will bypass `zone.js` patch for IE/Edge
 | 
						|
     */
 | 
						|
    // __Zone_enable_cross_context_check = true;
 | 
						|
  </script>
 | 
						|
  <!-- zone.js required by Angular -->
 | 
						|
  <script src="node_modules/zone.js/dist/zone.js"></script>
 | 
						|
 | 
						|
  <!-- application polyfills -->
 | 
						|
</code-example>
 |