fenghaolw / closure-demo

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

CircleCI

This repo is the demo/seed for bunding an Angular application with Google Closure Compiler. It contains a minimal Hello World application with a single component.

The compressed JS size for an Angular 6.0.0 Hello World app is 57.15kb.

-rw--- 1 alexeagle 46713 May  3 12:48 dist/bundle.js.brotli
-rw-r- 1 alexeagle 53397 May  3 12:48 dist/bundle.js.gz
-rw--- 1 alexeagle 11811 May  3 12:48 node_modules/zone.js/dist/zone.min.js.brotli
-rw-r- 1 alexeagle 12877 May  3 12:47 node_modules/zone.js/dist/zone.min.js.gz

See angular/angular#8550 for more context.

Try it

First, install brotli, which is a more modern compression algorithm than gzip. It gives a 13% smaller JS file, no work required! The commands below use it, but you don't have to.

On Mac, brew install brotli.

$ yarn install
$ yarn run build
$ yarn run serve

Where does the size come from?

$ yarn run explore

Notes

Requires Node >= 6.x since the ngc tool (and its deps) are now shipped as ES6 as well.

Requires Java installed to run the Closure Compiler. We recommend installing http://zulu.org/download-dev/.

About

License:MIT License


Languages

Language:TypeScript 40.7%Language:Shell 26.4%Language:HTML 22.8%Language:JavaScript 10.1%