),
2、模板文件的使用:
# 这四个都可以定位到文件
{% 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" />
3、各个文件夹的作用
STATIC_ROOT
在每个app里面新建一个static文件夹,将静态文件放到里面
在加载静态文件时,比如要在
模板中用到静态文件
,django会
自动
在每个app里面
搜索static文件夹
所以,不要把文件夹的名字写错, 否则django就找不到你的文件夹
因此,一般会这样设计:app01/static/app01_static/css
STATICFILES_DIRS
在所有的app文件外面,建立一个
公共的文件夹
,,也就是我们的
STATICFILES_DIRS: common_static
因为有些静态文件不是某个app独有的,那么就可以把它放到一个公共文件夹里面,方便管理
注意,建立一个
公共的静态文件
的文件夹只是一种
易于管理的做法
,但是
不是必须的
,
app是可以跨app应用静态文件的
,因为最后所有的静态文件都会
在STATIC_ROOT里面存在
那现在的问题是:如何让django知道你把一些静态文件放到app以外的公共文件夹中呢,那就需要配置STATICFILES_DIRS了
STATIC_URL
静态路由映射
django利用STATIC_URL来让浏览器可以直接访问静态文件
首先,到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会报错,那么,该如何做呢?下面给出答案:
5、static_url详解
那么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
6、static静态文件->模板使用
{% load staticfiles %}
<img src="{% static 'img/1.png' %}" />
我们在模板中添加一行
{% load staticfiles %}
,告诉django模板引擎我们要在模板中使用静态文件;
这样,便可以使用static模板标签引入静态目录中的文件;
static 'img/1.png' 告诉django,我们要显示目录名中img/1.png 的文件;
static标签会在img/1.png前加上STATIC_URL的指定URL,得到/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