关于Django中Static和Media的设置问题(尤其是css和js静态文件加载的问题),网上有很多回答,但是发现有相当一部分回答并不能解决问题。有的可能是Django版本问题,有的是把media和static搞混了。下面是关于Django 1.9+ 中static与media的总结:
区别:
- Static是不变的,形成网站的核心部件,如 CSS文件,JS文件,背景图片等;
- Media是变动的,由用户定义的文件,如 用户头像, 用户上传的图片或视频等。
配置方法:##
1.Static
- 在项目根目录新建static文件夹
- 在setting.py中设置:
- STATIC_DIR=os.path.join(BASE_DIR,'static')
- STATICFILES_DIRS=[STATIC_DIR,] (当由多个静态文件目录时,可加入)
- 在模板文件的 下面(不要写到最开头),写入{% load staticfiles %}
- 在模板文件中引用:{% static '<static文件夹中的目标文件路径>' %}
2. Media
- 在项目根目录新建media文件夹
- 在setting.py中设置
- MEDIA_DIR=os.path.join(BASE_DIR,'media')
- MEDIA_ROOT=MEDIA_DIR
- MEDIA_URL='/media/'(前后都有斜杠)
- TEMPLATES设置中的context_processor选项中加入:'django.template.context_processors.media',
- 在项目urls文件中
- from django.conf import settings
- from django.conf.urls.static import static
- 在文件最后加上: +static(settings.MEDIA_URL,document_root=settings.MEDIA_ROOT)
- 在模板文件中引用: