Skip to content
This repository has been archived by the owner on Mar 20, 2024. It is now read-only.
Alex Eagle edited this page May 12, 2017 · 1 revision

Closure Compiler is a JavaScript optimizer written and used at Google. We compile most of our Angular apps with it, to produce the smallest JavaScript bundles.

This is part of the "ABC" effort (Angular, Bazel, and Closure). See blog post.

Closure compiler is an advanced tool. We do not recommend using it for most Angular applications, instead please use the Angular CLI.

Introduction

First, some basic principles:

  1. Closure compiler is a global program analyzer and optimizer, and is too slow to run in development mode. You should only use it for production builds.
  2. Optimizers do their best work with code that has not been down-leveled. We pass the highest language that Closure compiler understands (currently ES2015).
  3. Closure compiler has several compilation levels. In this context, we always want to run with ADVANCED_OPTIMIZATION. Other levels are not an improvement over other tools.
  4. Code that is bundled by Closure must conform to some extra rules. Right now, developers are responsible for doing this. (We hope to add some static analyses to help with this.)

Known Issues

  1. Closure compiler bug with files that have no export statements. https://github.com/google/closure-compiler/issues/2247 This is known to affect files in rxjs. As a workaround, edit the file in node_modules/rxjs/*.js and add the line exports.__CLOSURE_WORKAROUND__ = true;
  2. Closure compiler requires Java is installed: https://github.com/google/closure-compiler/issues/2412 (Note that the closure-compiler-js version does not work)
  3. Allow comments in the closure.conf file https://github.com/google/closure-compiler/issues/2413
  4. Solve closure bug with rxjs files w/o exports https://github.com/google/closure-compiler/issues/2247
Clone this wiki locally