What is the the best Javascript compressor available? I'm looking for a tool that:
- Easy to use
- High compression rate
- Reliable end results (doesn't mess up the code)
What is the the best Javascript compressor available? I'm looking for a tool that:
YUICompressor is the way to go...great compression rate, well tested and in use among many top sites, and, well, personally recommended by me.
I've used it for my projects without a single JS error or hiccup. And it has nice documentation.
I've never used its CSS compression capabilities, but they exist as well.
*Note: Although Dean Edwards's /packer/ achieves a better compression rate than YUICompressor, I ran into a few JS errors when using it. *
Here's the source code of an HttpHandler which does that, maybe it'll help you
Google released Closure Compiler which seems to be generating the smallest files so far as seen here and here
Previous to that the various options were as follow
Basically Packer does a better job at initial compression , but if you are going to gzip the files before sending on the wire (which you should be doing) YUI Compressor gets the smallest final size.
The tests were done on jQuery code btw.
@daniel james mentions in the comment compressorrater which shows Packer leading the chart in best compression, so I guess ymmv
I use ShrinkSafe from the Dojo project - it is exceptional because it actually uses a JavaScript interpreter (Rhino) to deal with finding symbols in the code and understanding their scope, etc. which helps to ensure that the code will work when it comes out the other end, as opposed to a lot of compression tools which use regex to do the same (which is not as reliable).
I actually have an MSBuild task in a Web Deployment Project in my current Visual Studio solution that runs a script which in turn runs all of the solution's JS files through ShrinkSafe before we deploy and it works quite well.
EDIT: By the way, "best" is open to debate, since the criteria for "best" will vary depending on the needs of the project. Personally, I think ShrinkSafe is a good balance; for some people that think smallest size == best, it will be insufficient.
EDIT: It is worth noting that the YUI compressor also uses Rhino.
If you use Packer, just go far the 'shrink variables' option and gzip the resulting code. The base62 option is only for if your server cannot send gzipped files. Packer with 'shrink vars' achieves better compression the YUI, but can introduce bugs if you've skipped a semicolon somewhere.
base62 is basically a poor man's gzip, which is why gzipping base62-ed code gives you bigger files than gzipping shrink-var-ed code.
KJScompress
http://opensource.seznam.cz/KJScompress/index.html
Kjscompress/csskompress is set of two applications (kjscompress a csscompress) to remove non-significant whitespaces and comments from files containing JavaScript and CSS. Both are command-line applications for GNU/Linux operating system.
In searching silver bullet, found this question. For Ruby on Rails http://github.com/sstephenson/sprockets
I recently released UglifyJS, a JS compressor which is written in JavaScript (runs on NodeJS platform, but it can be easily modified to run on any JS engine, since it doesn't need any Node internals). It's a lot faster than both YUI Compressor and Google Closure, it compresses better than YUI on all scripts I tested it on, and it's safer than Closure (knows to deal with "eval" or "with").
Other than whitespace removal, UglifyJS also does the following:
PS: Oh, it can "beautify" as well. ;-)