先上一个项目文件结构:
# the settings above
# STATIC SETTINGS STATIC_URL = ‘/static/‘
# BASE_DIR 是项目的绝对地址 STATIC_ROOT = os.path.join(BASE_DIR, ‘collect_static‘)
#以下不是必须的 各个app共用的文件可以放在这 STATICFILES_DIRS = ( os.path.join(BASE_DIR, ‘common_static‘), )
# 这四个都可以定位到文件 {% load staticfiles %} <img src="{% static ‘img/1.png‘ %}" /> <img src="{% static ‘img/3.png‘ %}" /> <img src="{{STATIC_URL}}img/1.png" /> <img src="{{STATIC_URL}}img/3.png" />
是在部署的时候才发挥作用,执行 python managy.py collectstatic ,会在工程文件下生成(STATIC_ROOT )文件夹,把各个app下的静态文件收集到这个目录下。当然,需要配置Nginx。
静态文件的安放位置有两种:
在static标签中引用文件时有两个查找路径:
1、app下的static
2、工程下的commen_static(STATICFILES_DIRS)
STATICFILES_DIRS告诉django:
首先,到STATICFILES_DIRS里面寻找静态文件,
其次,再到各个app的static文件夹里面找
ps:(注意,django查找静态文件是惰性查找,查找到第一个,就停止查找了)
截止到目前为止,静态文件的机制已经可以运作了。
但是,有一个疑问,如何通过url来访问项目中的静态文件呢?可能会这么做:直接访问项目的静态文件的绝对路径,eg:home/blogproject/common_static/img/1.png,那么,在浏览器端需要这样:http://127.0.0.1:8000/home/blogproject/common_static/img/1.png
但是,很抱歉,如果这样做的话,Django会报错,那么,该如何做呢?下面给出答案:
那么django是如何让浏览器也可以访问服务器上的静态文件呢,前面已经说了,直接访问服务器本地的地址是不行的,那就需要一个映射,django利用STATIC_URL来让浏览器可以直接访问静态文件,比如:
STATIC_URL = ‘/static/‘
那么可以在浏览器上输入:
http://127.0.0.1:8000/static/img/1.png
http://127.0.0.1:8000/static/img/3.png
那么就相当与访问:
/home/blogproject/common_static/img/1.png
/home/blogproject/mytest/static/img/3.png
也就是说STATIC_URL = ‘/static/‘ 可以定位到各个app下的staic/和工程下的commen_static/。
所以在浏览器上,利用前缀 STATIC_URL的具体内容,来映射app下的static和STATICFILES_DIRS,
http://127.0.0.1:8000/static/ 相当于 本地地址的app/static 和 STATICFILES_DIRS
{% load staticfiles %} <img src="{% static ‘img/1.png‘ %}" />
django模板引擎生成如下html:
<img src="/static/img/1.png" />
如果使用:
<img src="{{STATIC_URL}}img/3.png" />
需要在setting.py中添加些设置:
1. INSTALLED_APPS 中,加入 ‘django.contrib.staticfiles‘ ,这个一般都有。
2. TEMPLATES 中,context_processors中,加入django.template.context_processors.static
Django --static 静态文件的配置(static_url/STATIC_ROOT/STATICFILES_DIRS)
原文:https://www.cnblogs.com/gengyufei/p/12632408.html