加载静态文件
在DTL
中,使用static
标签加载静态文件。 在模板中使用{% load static %}
来加载static
标签
步骤
- 确保
django.contrib.staticfiles
已经添加进settings.py
中的INSTALLED_APP
默认开启 - 确保在
setting.py
中设置了STATIC_URL
- 在已经安装的app下新建文件夹
static
(强制名),再在static
文件夹下创建文件夹(与当前app同名),将静态文件放到这个文件夹下。这是为了避免不同app的同名静态文件出现混淆,和templates一样会查询其他app的static文件夹 如果有不挂钩app的静态文件(或者不想在app下创建static),可以在
settings.py
中添加STATICFILES_DIRS
。设置后DTL
就会在该路径下查找静态文件。例如# 名字一个字都不能打错....
STATICFILES_DIRS = [
os.path.join(BASE_DIR, "static"), #在当前目录下的static文件夹
]
在模板中使用
load
标签加载static
标签。比如要加载当前app的static
文件夹的index.css
文件{% load static %}
<link rel="stylesheet" href="{% static 'app_name/index.css' %}">
如果不想每次都在模板中加载静态文件都用一次
{% load static %}
- 在
settings.py
的TEMPLATES
的OPTIONS
属性添加值'builtins':['django.templatetags.static']
- 就不用
{% load static %}
- 在
- 如果步骤1没有执行,就需要手动将请求静态文件的URL和静态文件的路径进行映射
这个没必要 ```python from django.conf imporjt settings from django.conf.urls.static import static
- 确保
urlpatterns = [
# 映射
] + static(settings.STATIC_URL, document_root=settings.STATIC_ROOT)
如果有完成步骤4 那么document_root=settings.STATICFILES_DIRS[0]
```