事关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的静态资源目录设置的相关知识以及本文开始处列出的三条语句的作用说清楚了。

相关推荐
韩立学长1 小时前
【开题答辩实录分享】以《基于Vue Node.js的露营场地管理系统的设计与实现》为例进行选题答辩实录分享
数据库·vue.js·node.js
mqiqe1 小时前
【AI】Weaviate向量数据库详细部署安装应用
数据库·人工智能
DolphinDB智臾科技1 小时前
工业数据流通难题与突破:基于时序数据库的选型思路
数据库·物联网·时序数据库
问道飞鱼1 小时前
【数据库知识】MySQL 数据类型详解:选型指南与实战最佳实践
数据库·mysql·数据类型
Xyz996_1 小时前
MySQL试验部署
数据库·mysql
小趴菜不能喝1 小时前
MySQL UTC时间
数据库·mysql
YJlio2 小时前
Autologon 学习笔记(9.16):无感登录的正确打开方式(原理、风险与替代方案)
数据库·笔记·学习
W***95242 小时前
Sql Server数据库远程连接访问配置
数据库
Q_Q5110082852 小时前
python+django/flask创新型产品提前购系统
spring boot·python·django·flask·node.js·php
Han.miracle2 小时前
数据库圣经--简单使用索引
java·数据库·sql·索引