STATICFILES_DIRS
STATIC_URL 好理解,就是映射到静态文件的url,一般为/static/ STATICFILES_DIRS 是个列表,放各个app的static目录及公共的static目录STATIC_ROOT 是总的static目录,可以使用命令自动收集static文件
更加详细的解释:
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目录差不多。
django处理static的方法是把各个app各自的static合并到一处
比如 djangodemo/djangodemo/static 放置公共静态文件 djangodemo/demo1/static 放置该app自己的静态文件 djangodemo/demo2/static 放置该app自己的静态文件 可以这么设置:123456789 | STATIC_ROOT = '/www/djangodemo/djangodemo/static ' STATIC_URL = '/static/' STATICFILES_DIRS = ( 'djangodemo/static' , 'demo1/static/' , 'demo2/static/' , ) |
1 | manage.py collectstatic |