阅读(110) (0)

Django4.0 开始-编写你的第一个Django应用,第6部分

2022-03-12 11:30:05 更新

本教程从教程第 5 部分结束的地方开始。我们已经建立了一个经过测试的网络投票应用程序,现在我们将添加一个样式表和一个图像。

除了服务端生成的 HTML 以外,网络应用通常需要一些额外的文件——比如图片,脚本和样式表——来帮助渲染网络页面。在 Django 中,我们把这些文件统称为“静态文件”。

对于小项目来说,这个问题没什么大不了的,因为你可以把这些静态文件随便放在哪,只要服务程序能够找到它们就行。然而在大项目——特别是由好几个应用组成的大项目中,处理不同应用所需要的静态文件的工作就显得有点麻烦了。

这就是 ​django.contrib.staticfiles​ 存在的意义:它将各个应用的静态文件(和一些你指明的目录里的文件)统一收集起来,这样一来,在生产环境中,这些文件就会集中在一个便于分发的地方。

自定义应用的界面和风格

首先,在你的 ​polls ​目录下创建一个名为 ​static ​的目录。Django 将在该目录下查找静态文件,这种方式和 Diango 在 ​polls/templates/​ 目录下查找 template 的方式类似。
Django 的 ​STATICFILES_FINDERS ​设置包含了一系列的查找器,它们知道去哪里找到 static 文件。​AppDirectoriesFinder ​是默认查找器中的一个,它会在每个 ​INSTALLED_APPS ​中指定的应用的子文件中寻找名称为 ​static ​的特定文件夹,就像我们在 ​polls ​中刚创建的那个一样。管理后台采用相同的目录结构管理它的静态文件。
在你刚创建的 ​static ​文件夹中创建一个名为 ​polls ​的文件夹,再在 ​polls ​文件夹中创建一个名为 ​style.css​ 的文件。换句话说,你的样式表路径应是 ​polls/static/polls/style.css​。因为 ​AppDirectoriesFinder ​的存在,你可以在 Django 中以 ​polls/style.css​ 的形式引用此文件,类似你引用模板路径的方式。

将以下代码放入样式表(​polls/static/polls/style.css​):

li a {
    color: green;
}

下一步,在 ​polls/templates/polls/index.html​ 的文件头添加以下内容:

{% load static %}

<link rel="stylesheet" type="text/css" href="{% static 'polls/style.css' %}">

{% static %}​ 模板标签会生成静态文件的绝对路径。
这就是你开发所需要做的所有事情了。
启动服务器(如果它正在运行中,重新启动一次):

...\> py manage.py runserver

重新载入 http://localhost:8000/polls/ ,你会发现有问题的链接是绿色的 (这是 Django 自己的问题标注方式),这意味着你追加的样式表起作用了。

添加一个背景图

接着,我们会创建一个用于存在图像的目录。在 ​polls/static/polls​ 目录下创建一个名为 ​images的子目录。在这个目录中,放一张名为 ​background.gif​ 的图片。换言之,在目录 ​polls/static/polls/images/background.gif​ 中放一张图片。
随后,在你的样式表(​polls/static/polls/style.css​)中添加:

body {
    background: white url("images/background.gif") no-repeat;
}

浏览器重载 http://localhost:8000/polls/,你将在屏幕的左上角见到这张背景图。

​注意:

{% static %} ​模板标签在静态文件(例如样式表)中是不可用的,因为它们不是由 Django 生成的。你应该始终使用 相对路径 在你的静态文件之间相互引用,因为这样你可以更改 ​STATIC_URL(由 static 模板标签使用来生成 URL),而无需修改大量的静态文件。