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


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

    STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
    STATIC_ROOT = os.path.join(BASE_DIR, 'static')
    STATIC_URL = '/static/'
    
    • 1
    • 2
    • 3

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

    首先说第1句和第2句:

    STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
    
    • 1
    STATIC_ROOT = os.path.join(BASE_DIR, 'static')
    
    • 1

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

    Django在加载HTML模板文件时对于静态文件的查找分为两种情况:
    这两种情况根据是否执行了下面这条语句来区分:

    python manage.py collectstatic
    
    • 1

    第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模板文件时对于静态文件的查找”的两种情况的介绍,相信您就知道了下面两句设置语句的作用了:

    STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
    
    • 1
    STATIC_ROOT = os.path.join(BASE_DIR, 'static')
    
    • 1

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

    STATIC_URL = '/static/'
    
    • 1

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

    {% static 'css/my_style.css' %}
    
    • 1

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

    {% load static %}
    
    • 1

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

    STATIC_URL = '/mystatic/'
    
    • 1

    那么对于语句:

    {% static 'css/my_style.css' %}
    
    • 1

    代表的路径字符串为:

    /mystatic/css/my_style.css
    
    • 1

    那么Django是如何去找寻文件 /mystatic/css/my_style.css 的呢?
    现在作如下假设:
    ①我的Django项目的名字为shop,路径为:

    E:/djproject/shop/
    
    • 1

    ②名字为shop的Django项目只有一个应用,名叫app1,并且在app1下建立了目录static
    ③我通过下面这条语句设置了STATICFILES_DIRS的值为 E:/djproject/shop/static(注意:static后没有/):

    STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
    
    • 1

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

    STATIC_ROOT = os.path.join(BASE_DIR, 'static_root')
    
    • 1

    那么当我还没有执行命令python manage.py collectstatic时,Django会按如下路径顺序去搜索静态资源/mystatic/css/my_style.css
    ①-各个应用中的static目录

    E:/djproject/shop/app1/static/mystatic/css/my_style.css
    
    • 1

    ②-STATICFILES_DIRS指定的目录

    E:/djproject/shop/static/mystatic/css/my_style.css
    
    • 1

    当我执行了命令python manage.py collectstatic后,Django会按如下路径顺序去搜索静态资源/mystatic/css/my_style.css
    ①-STATIC_ROOT指定的目录:

     E:/djproject/shop/static_root/mystatic/css/my_style.css
    
    • 1

    ②-STATICFILES_DIRS指定的目录

    E:/djproject/shop/static/mystatic/css/my_style.css
    
    • 1

    ③-各个应用中的static目录

    E:/djproject/shop/app1/static/mystatic/css/my_style.css
    
    • 1

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

  • 相关阅读:
    算法学习—双指针
    蓝桥杯十五届国赛模拟题1答案
    20年架构师带你彻底搞懂查询分离的实现思路
    【面试题】金九银十,你准备好面试了吗? (30w字前端面试题总结)(VUE)
    【Vue3】vue3中组合式Api的setup写法快速入门上手起步
    Spring学习从练气到化虚
    Avalonia开发(一)环境搭建
    经验分享|如何有效地进行审稿意见回复
    基于STM32 ZigBee无线远程火灾报警监控系统物联网温度烟雾
    CMU15445 (Fall 2020) 数据库系统 Project#1 - Buffer Pool 详解
  • 原文地址:https://blog.csdn.net/wenhao_ir/article/details/134493471