django-pipeline 是一个 Django 下很是方便的静态资源管理 app,尤为是 1.2 版本以后,利用 django-staticfiles
的collectstatic
命令,在开发、部署环境下切换很是方便。css
写 codinn.com 代码的时候,静态资源管理方面遇到了一些烦人的事情:python
django-pipeline 经过静态资源版本化、自动 minify、分组合并 CSS/JS 文件、兼容 django-staticfiles
URL 规则以及collectstatic
命令。django
图个省心,我一般使用 jsmin/cssmin
这两个 Python minifier:浏览器
PIPELINE_JS_COMPRESSOR = 'pipeline.compressors.jsmin.JSMinCompressor'
PIPELINE_CSS_COMPRESSOR = 'pipeline.compressors.cssmin.CssminCompressor'
缓存
可是 jsmin
年久失修,实际使用结论是:jsmin
是有 bug 的,jQuery 开发库用 jsmin
minify 后被破坏,压根没法正常工做。可是 jQuery 官方 minify 以后的 JS 文件再用 jsmin
minify 以后却没有问题。app
虽然有规避方案,但始终对 jsmin
不放心,索性改用 slimit
,暂时还没发现 JS 被破坏的问题。python2.7
django-pipeline 未提供对 slimit
的支持,不过 pipeline 的扩展性还不错,写一个 slimit
扩展也是分钟的事情:post
from __future__ import absolute_import
编码
from pipeline.compilers import CompilerBase
调试
class SlimItCompiler(CompilerBase):
"""
JS compressor based on the Python library slimit
(http://pypi.python.org/pypi/slimit/).
"""
def compress_js(self, js):
from slimit import minify
return minify(js)
将以上代码保存成 slimit
文件,扔在项目中的某个包目录下便可,再修改 settings
:
PIPELINE_JS_COMPRESSOR = 'lib.slimit.SlimItCompiler'
启用 django-pipeline
后,执行 manage.py collectstatic
若是碰到下面的错误提示:
File ".../ENV/local/lib/python2.7/site-packages/django/contrib/staticfiles/storage.py", line 226, in post_process content = pattern.sub(converter, content) UnicodeDecodeError: 'ascii' codec can't decode byte 0xef in position 0: ordinal not in range(128)
八成是由于 CSS 文件中含有中文或其它非拉丁文字。我在使用 @font-face
图标文字时碰到了这个问题,这是 django staticfiles 包的一个 bug,解决方法是修改 /django/contrib/staticfiles/storage.py
文件,把出错的那行代码:
content = original_file.read()
替换成:
content = original_file.read().decode('utf-8')
用这个方法的前提是:你的 CSS 文件必须保证 utf-8 编码,不然依然会出错。
PS,给 Django 项目提交了一个 bug 报告:https://code.djangoproject.com/ticket/18430