Skip to content

wbr911/jquery

 
 

Repository files navigation

Using jQuery with Closure Compiler Advanced Optimizations

Closure-compiler has a custom pass specifically to process jQuery. This branch of jQuery has the necessary changes and annotations to fully work with Closure-compiler.

Getting the code

The easist method is to download the pre-built source.

You can also build your own version from source. Use the same directions as building the main jQuery source, but substitute cloning this repository instead of the main jQuery repository. You'll also need to checkout the closure-compiler-1.9 branch once you clone the repository. You need to clone my sizzle repository into the src folder and checkout the closure-compiler-1.9 branch of it too.

How to build your jQuery code with closure-compiler

Make sure to use the --process_jquery_primitives flag of the compiler. It won't compile correctly without it.

Example compilation command:

java -jar compiler.jar
  --compilation_level ADVANCED_OPTIMIZATIONS
  --warning_level VERBOSE
  --process_jquery_primitives
  --js jquery.closure-compiler.js
  --js myjqueryplugin.js
  --output_wrapper "(function() {%output%})()"

jQuery Types

Properties and Quotes

Most properties can and should be used unquoted (jQuery.myPropery as opposed to jQuery["myProperty"]) This build does support the experimental type-based optimizations which are enabled using the --use_types_for_optimization flag

Deprecated Methods

Many of the deprecated methods have been removed and a future build will probably remove any I have missed. You shouldn't be using deprecated methods.

Miscellaneous

It's been a challenge modifying jQuery style code into a format that can be successfully processed by Closure-compiler. The public API methods all have type annotations, but the same type-casting requirements that come with using the official externs, apply here as well. Some dead code elimination does occur, but not as much as I had hoped. It will take some time to identify what blocks particular sections of code from being eliminated.

More information on how the compiler handles jQuery

Reporting Bugs

If you encounter bugs (which is highly probable), you should NOT post them on the closure-compiler issue tracker or on the official jQuery issue tracker. Instead, post them to this GitHub repository

About

jQuery JavaScript Library

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 98.9%
  • Other 1.1%