加载静态文件
在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]
```
