django1.3新加入了一个静态资源管理的app,django.contrib.staticfiles。在以往的django版本中,静态资源的管理一贯都是个问题。部分app发布的时候会带上静态资源文件,在部署的时候你必须手动从各个app中将这些静态资源文件复制到同一个static目录。在引入staticfiles后,你只须要执行./manage.py collectstatic就能够很方便的将所用到app中的静态资源复制到同一目录。python
staticfiles的引入,方便了django静态文件的管理,不过感受staticfiles的文档写的并非太清楚,初次使用的时候仍是让我有些困惑。django
下面简单的介绍一下staticfiles的主要配置:服务器
- STATIC_ROOT:运行manage.py collectstatic后静态文件将复制到的目录。注意:不要把你项目的静态文件放到这个目录。这个目录只有在运行collectstatic时才会用到。我最开始想固然的觉得这个目录和MEDIA_ROOT的做用是相同的,导致在开发环境下一直没法找到静态文件。
- STATIC_URL:设置的static file的起始url,这个只能够在template里面引用到。这个参数和MEDIA_URL的含义差很少。
- STATICFILES_DIRS:除了各个app的static目录之外还须要管理的静态文件位置,好比项目公共的静态文件差很少。和TEMPLATE_DIRS的含义差很少。
- 各个APP下static/目录下的静态文件django的开发服务器会自动找到,这点和之前APP下的templates目录差很少。
- 在urls.py中加入静态文件处理的代码
from django.contrib.staticfiles.urls import staticfiles_urlpatterns# ... the rest of your URLconf goes here ... urlpatterns += staticfiles_urlpatterns()