Skip to main content

Compresses linked and inline JavaScript or CSS into single cached files.

Project description

https://coveralls.io/repos/django-compressor/django-compressor/badge.png?branch=develop https://pypip.in/v/django_compressor/badge.png https://pypip.in/d/django_compressor/badge.png Build Status

Django Compressor combines and compresses linked and inline Javascript or CSS in a Django template into cacheable static files by using the compress template tag.

HTML in between {% compress js/css %} and {% endcompress %} is parsed and searched for CSS or JS. These styles and scripts are subsequently processed with optional, configurable compilers and filters.

The default filter for CSS rewrites paths to static files to be absolute and adds a cache busting timestamp. For Javascript the default filter compresses it using jsmin.

As the final result the template tag outputs a <script> or <link> tag pointing to the optimized file. These files are stored inside a folder and given a unique name based on their content. Alternatively it can also return the resulting content to the original template directly.

Since the file name is dependent on the content these files can be given a far future expiration date without worrying about stale browser caches.

The concatenation and compressing process can also be jump started outside of the request/response cycle by using the Django management command manage.py compress.

Configurability & Extendibility

Django Compressor is highly configurable and extendible. The HTML parsing is done using lxml or if it’s not available Python’s built-in HTMLParser by default. As an alternative Django Compressor provides a BeautifulSoup and a html5lib based parser, as well as an abstract base class that makes it easy to write a custom parser.

Django Compressor also comes with built-in support for CSS Tidy, YUI CSS and JS compressor, yUglify CSS and JS compressor, the Google’s Closure Compiler, a Python port of Douglas Crockford’s JSmin, a Python port of the YUI CSS Compressor cssmin and a filter to convert (some) images into data URIs.

If your setup requires a different compressor or other post-processing tool it will be fairly easy to implement a custom filter. Simply extend from one of the available base classes.

More documentation about the usage and settings of Django Compressor can be found on django-compressor.readthedocs.org.

The source code for Django Compressor can be found and contributed to on github.com/django-compressor/django-compressor. There you can also file tickets.

The in-development version of Django Compressor can be installed with pip install http://github.com/django-compressor/django-compressor/tarball/develop.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django_compressor-1.4.tar.gz (106.8 kB view details)

Uploaded Source

Built Distribution

django_compressor-1.4-py2.py3-none-any.whl (115.0 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file django_compressor-1.4.tar.gz.

File metadata

File hashes

Hashes for django_compressor-1.4.tar.gz
Algorithm Hash digest
SHA256 b26034230efcef7d60e5267890eda656dfc49c567f27125d907eee4fe7f9a6ec
MD5 dc050f1a85f83f927f94bcb09e8bdd0f
BLAKE2b-256 52d15571be2f370a853c221ea9f52e1f82deaca1cd6d5b83651853a0896bddd1

See more details on using hashes here.

File details

Details for the file django_compressor-1.4-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for django_compressor-1.4-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 504e441967ac78604ab35f030018fc9a6fa270e6a6e98471d2311fd77f70674b
MD5 904e81d37a03c7af407acd8132f3ce69
BLAKE2b-256 6e90262d35aa46729e9cb9146601589bdc23c428f3ae6659a95e5f801be34980

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page