首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

第一个 Django 应用,第 6 部分

这一篇从 教程第 5 部分 结尾的地方继续讲起。在上一节中我们为网络投票应用编写了测试,而现在我们要为它加上样式和图片。

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

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

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

自定义应用的界面和风格

首先,在你的目录下创建一个名为的目录。Django 将在该目录下查找静态文件,这种方式和 Diango 在目录下查找 template 的方式类似。

Django 的设置包含了一系列的查找器,它们知道去哪里找到 static 文件。是默认查找器中的一个,它会在每个中指定的应用的子文件中寻找名称为的特定文件夹,就像我们在中刚创建的那个一样。管理后台采用相同的目录结构管理它的静态文件。

在你刚创建的文件夹中创建一个名为的文件夹,再在文件夹中创建一个名为的文件。换句话说,你的样式表路径应是。因为的存在,你可以在 Django 中简单地使用以的形式引用此文件,类似你引用模板路径的方式。

静态文件命名空间

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

将以下代码放入样式表():

polls/static/polls/style.css

lia{

color:green;

}

下一步,在的文件头添加以下内容:

polls/templates/polls/index.html

{%loadstatic%}

模板标签会生成静态文件的绝对路径。

以上就是你全部需要做的事。浏览器重载,然后你可以看到投票链接是绿色的(Django 样式),这意味着你的样式表被正确加载了。

添加一个背景图

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

随后,在你的样式表()中添加:

polls/static/polls/style.css

body{

background:whiteurl("images/background.gif")no-repeat;

}

浏览器重载,你将在屏幕的左上角见到这张背景图。

Warning

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

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180724G1V4VF00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券