【Django文档转译】第1章:快速入门——第6节: 静态文件

网友投稿 838 2022-11-30

【Django文档转译】第1章:快速入门——第6节: 静态文件

【Django文档转译】第1章:快速入门——第6节: 静态文件

这一篇从 教程第 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 的形式引用此文件,类似你引用模板路径的方式。

静态文件命名空间

虽然我们 可以 像管理模板文件一样,把 static 文件直接放入 polls/static ——而不是创建另一个名为 polls 的子文件夹,不过这实际上是一个很蠢的做法。​​Django 只会使用第一个找到的静态文件。如果你在 其它 应用中有一个相同名字的静态文件,Django 将无法区分它们。​​​我们需要指引 Django 选择正确的静态文件,而最简单的方式就是把它们放入各自的 命名空间 。也就是​​把这些静态文件放入 另一个 与应用名相同的目录中。​​

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

polls/static/polls/style.css¶

li a { color: green;}

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

{% load static %}{% static %}

这就是你开发所需要做的所有事情了。

启动服务器(如果它正在运行中,重新启动一次):

$ python manage.py runserver

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

添加一个背景图¶

接着,我们会创建一个用于存在图像的目录。在 polls/static/polls 目录下创建一个名为 images 的子目录。在这个目录中,放一张名为 background.gif 的图片。换言之,在目录 polls/static/polls/images/background.gif 中放一张图片。

随后,在你的样式表(polls/static/polls/style.css)中添加:

polls/static/polls/style.css¶

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

浏览器重载 ​​static %} 模板标签在静态文件(例如样式表)中是不可用的,因为它们不是由 Django 生成的。​​​你仍需要使用 相对路径 的方式在你的静态文件之间互相引用。这样之后,你就可以任意改变 ​​STATIC_URL(由 :ttag:static 模板标签用于生成 URL),​​而无需修改大量的静态文件。

这些只是 基础 。更多关于设置和框架的资料,参考 静态文件解惑 和 静态文件指南。部署静态文件 介绍了如何在真实服务器上使用静态文件。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:【Django文档转译】第1章:快速入门——第5节: 测试
下一篇:【Django文档转译】第2章:模型层——第1节:模型(模块3:Meta 选项)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~