Django模板中如何使用static和media标签加载静态和媒体文件

2023-04-09 00:00:00 静态 如何使用 媒体文件

在Django模板中,我们可以使用static和media标签来加载静态和媒体文件。

使用static标签加载静态文件:

首先,在settings.py中,需要设置STATICFILES_DIRS和STATIC_URL设置。STATICFILES_DIRS是静态文件储存目录,STATIC_URL是该目录在浏览器中的URL地址。

在模板中,使用static标签来加载静态文件。语法如下:

{% load static %}

Pidancode Logo

上面的代码中,{% load static %}是加载静态文件的标签。在src属性中,https://www.pidancode.com/a/{% static 'images/pidancode.png' %}表示静态文件在STATICFILES_DIRS目录下images文件夹下的pidancode.png文件。

使用media标签加载媒体文件:

在settings.py中,需要设置MEDIA_ROOT和MEDIA_URL设置。MEDIA_ROOT是媒体文件储存目录,MEDIA_URL是该目录在浏览器中的URL地址。

在模板中,使用media标签来加载媒体文件。语法如下:

{% load static %}



在上面的代码中,{% load media %}是加载媒体文件的标签。在source标签中,使用变量{{ media_url }}来表示媒体文件在MEDIA_ROOT目录下的music文件夹下的pidancode.mp3文件,并指定文件类型为audio/mpeg。

需要注意的是,在使用media标签时,需要将MEDIA_ROOT和MEDIA_URL传递到模板上下文中,才能在模板中使用它们。例如,在视图函数中可以这样写:

def my_view(request):
context = {
'media_url': settings.MEDIA_URL,
}
return render(request, 'my_template.html', context)

在模板中就可以直接使用{{ media_url }}变量来加载媒体文件。

综上所述,我们可以使用static和media标签来加载静态和媒体文件。使用static标签需要设置STATICFILES_DIRS和STATIC_URL设置,使用media标签需要设置MEDIA_ROOT和MEDIA_URL设置,并将它们传递到模板上下文中。

相关文章