事关Django的静态资源目录设置(Django的setting.py中的三句静态资源(static)目录设置语句分别是什么作用?)

在Django的setting.py中常见的三句静态资源(static)目录设置语句如下:

python 复制代码
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
STATIC_ROOT = os.path.join(BASE_DIR, 'static')
STATIC_URL = '/static/'

下面介绍这三句话的作用。

首先说第1句和第2句:

python 复制代码
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
python 复制代码
STATIC_ROOT = os.path.join(BASE_DIR, 'static')

要明白这两句话的作用,那首先要搞清楚Django在加载HTML模板文件时对于静态文件的查找是怎么样的。

Django在加载HTML模板文件时对于静态文件的查找分为两种情况:

这两种情况根据是否执行了下面这条语句来区分:

bash 复制代码
python manage.py collectstatic

第01种-没有执行命令python manage.py collectstatic的情况

在这种情况下,Django在加载HTML模板文件时对于静态文件的查找是按下面的顺序来进行的:

  1. 各个应用的static目录

    Django 会首先查找每个应用中的 static 目录,这是默认的静态文件存放位置。每个应用通常都有一个 static 目录,用于存放该应用的静态文件。如果你在应用中创建了这样的目录,Django 将会在其中查找相应的静态文件。

  2. STATICFILES_DIRS中的静态文件

    如果在各个应用的 static 目录中找不到所需的静态文件,Django 将在 STATICFILES_DIRS 指定的目录列表中进行查找。这些目录通常包括应用中的 static 目录以及其他自定义的静态文件目录。

  3. Django提供的默认静态文件

    Django 在运行时也会提供一些默认的静态文件,例如 admin 应用的静态文件。这些文件通常不需要你手动收集,Django 会自动处理。

这种情况下,没有集中存放静态文件,而是直接在各个应用的 static 目录中查找。这在开发阶段是方便的,但在生产环境中通常会通过执行 python manage.py collectstatic 来将静态文件集中存放到一个目录,以提高性能和更好地组织静态文件,于是便产生了第2种情况。

第02种-执行命令python manage.py collectstatic的情况

当运行 python manage.py collectstatic 命令时,Django 会从各个应用的 static 目录以及 STATICFILES_DIRS 指定的目录中收集静态文件,并将它们复制到 STATIC_ROOT 指定的目录下。注意:复制的时候会把相应的目录结构也复制上,而不只是静态文件哈。这样做的目的是为了在生产环境中集中存放所有静态文件,以便于 Web 服务器更有效地提供它们。

执行命令 python manage.py collectstatic 后,Django在加载HTML模板文件时对于静态文件的查找则变成了下面的顺序来进行了(注意:此时与第1种情况的顺序有很大的区别了):

  1. STATIC_ROOT中的静态文件

    Django 会首先查找STATIC_ROOT目录中是否存在所需的静态文件。这是因为STATIC_ROOT是用于收集所有静态文件的根目录,它们都被复制到这个目录下。

  2. STATICFILES_DIRS中的静态文件

    如果在STATIC_ROOT中找不到所需的静态文件,Django 将在STATICFILES_DIRS指定的目录列表中进行查找。这些目录通常包括应用中的static目录以及其他自定义的静态文件目录。

  3. 各个应用的static目录

    如果在以上步骤中都找不到所需的静态文件,Django 将在各个应用的static目录中查找。每个Django应用通常都有一个static目录,用于存放该应用的静态文件。

当你在模板文件中引用静态文件时,Django 使用{% static %} 模板标签来生成对应的 URL。这个标签会首先查找STATIC_ROOT,然后是STATICFILES_DIRS,最后是各个应用的static目录。

读懂了上面对"Django在加载HTML模板文件时对于静态文件的查找"的两种情况的介绍,相信您就知道了下面两句设置语句的作用了:

python 复制代码
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
python 复制代码
STATIC_ROOT = os.path.join(BASE_DIR, 'static')

接下来说下面这条语句的作用:

python 复制代码
STATIC_URL = '/static/'

这句话只有在Django的HTML模板中使用了如下的模板语言时才有作用:

python 复制代码
{% static 'css/my_style.css' %}

当jango的HTML模板中使用了上面的模板语言,并在HTML模板文件的开头处写上了下面这条语句时:

python 复制代码
{% load static %}

那么此时{% static 'css/my_style.css' %}中的static就作为是静态文件的路径前缀 了,如果此时 STATIC_URL 的值用下面这条语句设定为'/mystatic/'

python 复制代码
STATIC_URL = '/mystatic/'

那么对于语句:

python 复制代码
{% static 'css/my_style.css' %}

代表的路径字符串为:

python 复制代码
/mystatic/css/my_style.css

那么Django是如何去找寻文件 /mystatic/css/my_style.css 的呢?

现在作如下假设:

①我的Django项目的名字为shop,路径为:

bash 复制代码
E:/djproject/shop/

②名字为shop的Django项目只有一个应用,名叫app1,并且在app1下建立了目录static 。

③我通过下面这条语句设置了STATICFILES_DIRS的值为 E:/djproject/shop/static(注意:static后没有/):

python 复制代码
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]

④我通过下面这条语句设置了STATIC_ROOT的值为 E:/djproject/shop/static_root(注意:static_root后没有/):

python 复制代码
STATIC_ROOT = os.path.join(BASE_DIR, 'static_root')

那么当我还没有执行命令python manage.py collectstatic时,Django会按如下路径顺序去搜索静态资源/mystatic/css/my_style.css

①-各个应用中的static目录

bash 复制代码
E:/djproject/shop/app1/static/mystatic/css/my_style.css

②-STATICFILES_DIRS指定的目录

bash 复制代码
E:/djproject/shop/static/mystatic/css/my_style.css

当我执行了命令python manage.py collectstatic后,Django会按如下路径顺序去搜索静态资源/mystatic/css/my_style.css

①-STATIC_ROOT指定的目录:

bash 复制代码
 E:/djproject/shop/static_root/mystatic/css/my_style.css

②-STATICFILES_DIRS指定的目录

bash 复制代码
E:/djproject/shop/static/mystatic/css/my_style.css

③-各个应用中的static目录

bash 复制代码
E:/djproject/shop/app1/static/mystatic/css/my_style.css

至此,就将Django的静态资源目录设置的相关知识以及本文开始处列出的三条语句的作用说清楚了。

相关推荐
哭哭啼41 分钟前
Redis环境部署(主从模式、哨兵模式、集群模式)
数据库·redis·缓存
咕噜Yuki06091 小时前
OCP证书如何下载?
数据库·ocp·证书查询
冬瓜3121 小时前
linux-c 使用c语言操作sqlite3数据库-1
数据库·sqlite
夜色呦1 小时前
现代电商解决方案:Spring Boot框架实践
数据库·spring boot·后端
WangYaolove13142 小时前
请解释Python中的装饰器是什么?如何使用它们?
linux·数据库·python
我是黄大仙2 小时前
利用飞书多维表格自动发布版本
运维·服务器·数据库·飞书
曾经的三心草2 小时前
Mysql之约束与事件
android·数据库·mysql·事件·约束
WuMingf_2 小时前
redis
数据库·redis
张某布响丸辣2 小时前
SQL中的时间类型:深入解析与应用
java·数据库·sql·mysql·oracle