Django4全栈进阶之路9 STATIC静态文件路径设置、MEDIA媒体文件路径设置
在 Django 4 中,可以在 settings.py 文件中设置 STATICFILES_DIRS 来指定应用程序静态文件所在的文件夹路径,设置 STATIC_ROOT 来指定收集所有应用程序静态文件的目标文件夹路径。例如:
# settings.py
STATICFILES_DIRS = [
os.path.join(BASE_DIR, 'static'),
] STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles')
其中,STATICFILES_DIRS 是一个列表,包含应用程序静态文件所在的文件夹路径,STATIC_ROOT 是一个字符串,指定收集所有应用程序静态文件的目标文件夹路径。
在生产环境中,需要运行 collectstatic 命令来收集所有应用程序静态文件到 STATIC_ROOT 文件夹。可以使用以下命令:
python manage.py collectstatic
对于媒体文件,可以在 settings.py 文件中设置 MEDIA_ROOT 和 MEDIA_URL,如下所示:
# settings.py
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
MEDIA_URL = '/media/'
其中,MEDIA_ROOT 指定媒体文件的本地存储路径,MEDIA_URL 指定媒体文件的 URL 前缀。
需要注意的是,在生产环境中,需要配置 Web 服务器(如 Nginx 或 Apache)来提供静态文件和媒体文件的服务,而不是使用 Django 4 提供的服务。在开发环境中,Django 4 会自动提供静态文件和媒体文件的服务。
示例:
# 设置静态资源的保存路径
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')] STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(BASE_DIR, '/static')
# 设置媒体资源的保存路径
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
MEDIA_URL = '/media/'
在 Django 4 中,可以在主路由文件(通常是 urls.py)中设置 STATIC 和 MEDIA 路径,以确保能够正确地访问静态文件和媒体文件。
对于静态文件,可以使用以下代码:
# urls.py
from django.conf import settings
from django.conf.urls.static import static urlpatterns = [
# ... 其他 URL 模式 ...
] # 只在开发环境中使用,生产环境需要通过 Web 服务器提供静态文件服务
if settings.DEBUG:
urlpatterns += static(settings.STATIC_URL, document_root=settings.STATIC_ROOT)
这段代码使用了 static() 函数来将静态文件路径和 URL 绑定在一起,settings.STATIC_URL 是静态文件 URL 的前缀,settings.STATIC_ROOT 是静态文件的本地存储路径。
对于媒体文件,可以使用以下代码:
# urls.py
from django.conf import settings
from django.conf.urls.static import static urlpatterns = [
# ... 其他 URL 模式 ...
] # 只在开发环境中使用,生产环境需要通过 Web 服务器提供媒体文件服务
if settings.DEBUG:
urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
这段代码使用了 static() 函数来将媒体文件路径和 URL 绑定在一起,settings.MEDIA_URL 是媒体文件 URL 的前缀,`settings.MEDIA_ROOT` 是媒体文件的本地存储路径。
需要注意的是,以上代码中的 if settings.DEBUG 是一个条件语句,只有在开发环境中才需要使用。在生产环境中,通常会使用 Web 服务器(如 Apache 或 Nginx)来提供静态文件和媒体文件的服务,而不是让 Django 直接提供。
因此,如果您的 Django 应用程序将在生产环境中运行,您需要在 Web 服务器配置中设置静态文件和媒体文件的路径,而不是在 Django 项目中进行设置。
BootStrap:
BootStrap官网:https://www.bootcss.com/
本次使用Bootstrap 4.6.2版本
要在 Django 中使用 Bootstrap 4.6 的静态文件,可以按照以下步骤操作:
2、首先,将 Bootstrap 4.6 的 CSS 和 JavaScript 文件下载到您的 Django 项目中的某个静态文件目录中,例如 static 文件夹下的 css 和 js 文件夹中。这里我们直接将整个文件拷贝到static.

2、然后,在 base.html 模板文件中,通过以下方式引用 Bootstrap 的 CSS 和 JavaScript 文件:
{% load static %}
<!-- 引入 Bootstrap 的 CSS 文件 -->
<link rel="stylesheet" href="{% static 'css/bootstrap.min.css' %}">
<!-- 在页面底部引入 jQuery 和 Bootstrap 的 JavaScript 文件 -->
<script src="{% static 'js/jquery.min.js' %}"></script>
<script src="{% static 'js/bootstrap.min.js' %}"></script>
这里,我们使用 Django 内置的 {% static %} 模板标签来生成静态文件的 URL,这个标签会根据您在 settings.py 中设置的静态文件路径来生成 URL。
Bootstrap 4.6还依赖jquery.min.js吗?
是的,Bootstrap 4.6 仍然依赖 jQuery。在使用 Bootstrap 4.6 的 JavaScript 组件之前,您需要先引入 jQuery。
在您的 Django 项目中,您可以在 static 文件夹中的 js 文件夹中,将 jQuery 的 JavaScript 文件下载到本地。然后,在您的模板文件中,可以按照以下方式引入 jQuery 和 Bootstrap 的 JavaScript 文件:
{% load static %}
<!-- 引入 jQuery 的 JavaScript 文件 -->
<script src="{% static 'js/jquery.min.js' %}"></script>
<!-- 引入 Bootstrap 的 JavaScript 文件 -->
<script src="{% static 'js/bootstrap.min.js' %}"></script>
注意,jQuery 必须在 Bootstrap 的 JavaScript 文件之前被引入,因为 Bootstrap 的 JavaScript 代码依赖于 jQuery。
希望这个回答能够帮助您理解 Bootstrap 4.6 仍然依赖于 jQuery。
Bootstrap 4.6 兼容 jQuery 3.x 版本,您可以从 jQuery 官网(https://jquery.com/)下载最新的 jQuery 3.x 版本。
在下载页面上,您可以找到“Download”按钮,然后选择需要的版本进行下载。推荐下载 jQuery 3.6.x 版本,这是目前的最新稳定版本。
如果您想下载压缩版本的 jQuery,可以选择下载“Production version”,如果您想下载未压缩版本的 jQuery,可以选择下载“Development version”。
以下是 jQuery 3.6.0 压缩版和未压缩版的下载链接:
希望这个回答能够帮助您找到适合 Bootstrap 4.6 的 jQuery 版本,并提供相应的下载链接。
Django4全栈进阶之路9 STATIC静态文件路径设置、MEDIA媒体文件路径设置的更多相关文章
- python 全栈开发之路 day1
python 全栈开发之路 day1 本节内容 计算机发展介绍 计算机硬件组成 计算机基本原理 计算机 计算机(computer)俗称电脑,是一种用于高速计算的电子计算机器,可以进行数值计算,又可 ...
- web前端全栈学习之路
web前端全栈学习之路 --- 陆续更新中 一.HTML相关 1.HTML常用标签:http://www.cnblogs.com/wyb666/p/8733699.html 2.HTML5基础: 3. ...
- 你的Node应用,对接分布式链路跟踪系统了吗?(一) 原创: 金炳 Node全栈进阶 4天前 戳蓝字「Node全栈进阶」关注我们哦
你的Node应用,对接分布式链路跟踪系统了吗?(一) 原创: 金炳 Node全栈进阶 4天前 戳蓝字「Node全栈进阶」关注我们哦
- C#.Net全栈工程师之路-学习路径
C#.Net全栈工程师之路-学习路径 按架构分: C/S架构: B/S架构: Mobile移动开发: 按技术点分: C#编程基础以及OOP面向对象编程: 数据库基础以及高级应用(MYSQL+MSSQL ...
- 战争热诚的python全栈开发之路
从学习python开始,一直是自己摸索,但是时间不等人啊,所以自己为了节省时间,决定报个班系统学习,下面整理的文章都是自己学习后,认为重要的需要弄懂的知识点,做出链接,一方面是为了自己找的话方便,一方 ...
- Python全栈开发之路 【第四篇】:Python基础之函数
本节内容 函数def: 1.位置参数,默认参数 2.位置参数,关键参数 3.如果参数中出现 *users,传递的参数就可以不再是固定的个数, 传过来的所有元素进行打包成元组 *args,**kwarg ...
- Python全栈开发之路 【第一篇】:Python 介绍
本节内容 一.Python介绍 python的创始人为荷兰人——吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本 ...
- Python全栈开发之路 【第七篇】:面向对象编程设计与开发(1)
本节内容 一.编程范式 编程指的是写程序.敲代码,就是指程序员用特定的语法.数据结构和算法编写的代码,目的是来告诉计算机如何执行任务的. 在编程的世界里最常见的两大流派是:面向过程与面向对象.“功夫的 ...
- Python全栈开发之路 【第三篇】:Python基础之字符编码和文件操作
本节内容 一.三元运算 三元运算又称三目运算,是对简单的条件语句的简写,如: 简单条件语句: if 条件成立: val = 1 else: val = 2 改成三元运算: val = 1 if 条件成 ...
- Python全栈开发之路 【第五篇】:Python基础之函数进阶(装饰器、生成器&迭代器)
本节内容 一.名称空间 又名name space,就是存放名字的地方.举例说明,若变量x=1,1存放于内存中,那名字x存放在哪里呢?名称空间正是存放名字x与1绑定关系的地方. 名称空间共3种,分别如下 ...
随机推荐
- Python学习笔记--文件的相关操作
文件的读取操作 读操作 实现: read()--读完 read(10)--读取10个字节 readline()--将所有行并到一行输出 readlines()--一次读取一行 文件的关闭: 实现: 上 ...
- Feign调用报错The bean 'XXX.FeignClientSpecification', defined in null, could not be registered....的解决办法
问题描述: 创建了两个远程调用类,一个是调用退款的,一个是调用折扣的 但是两个调用类是调用的同一个微服务 都叫@FeignClient(value = "xxx-shop") 如何 ...
- ASP.NET Core使用filter和redis实现接口防重
背景 日常开发中,经常需要对一些响应不是很快的关键业务接口增加防重功能,即短时间内收到的多个相同的请求,只处理一个,其余不处理,避免产生脏数据.这和幂等性(idempotency)稍微有点区别,幂等性 ...
- Python常见加密解密算法
Python爬虫常见加密解密算法 url encode加密 简介:当url地址含有中文,或者参数有中文的时候,这个算是很正常了,但是把这样的url作为参数传递的时候(最常见的callback) ,需要 ...
- Linux & 标准C语言学习 <DAY10>
一.函数递归 函数自己调用自己的行为,叫做函数递归 递归是分治思想的一种具体实现,就是把一个复杂而庞大的问题,分解成若干个相似的小问题,解决所有小问题以解决大问题 如果函数递归 ...
- (数据科学学习手札150)基于dask对geopandas进行并行加速
本文示例代码已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 大家好我是费老师,geopandas作为我们非常 ...
- uniapp踩坑必备笔记
1.[配置]应用版本号名称有一个规则的字符串:1.0.0,规则是:大版本号,中版本号,小版本号. 2.[配置]应用版本号中的小版本号不能超过9,超过9的需要向上一个版本号进一(逢十进一). 3.[配置 ...
- 【ASP.NET Core】在node.js上托管Blazor WebAssembly应用
由于 Blazor-WebAssembly 是在浏览器中运行的,通常不需要执行服务器代码,只要有个"窝"能托管并提供相关文件的下载即可.所以,当你有一个现成的 Blazor was ...
- 通过使用chatgpt 逐步解决egg项目学习的一些问题【笔记】
我的需求提问 创建一个html页面,这个页面包括通过学生id查询学生详情的组件,和通过学生姓名,身份证,选择班级的组件,并把代码告诉我 chatgpt回答 好的,以下是一个包含两个组件的HTML页面, ...
- 设置Mysql sort_buffer_size参数
按照官网的解释:Each session that must perform a sort allocates a buffer of this size. sort_buffer_size is n ...