在上一节中我们为网络投票应用编写了测试,而现在我们要为它加上样式和图片。

除了服务端生成的 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):

li a {color: green;
}

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

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

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

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

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

python 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(由 :ttag:static 模板标签用于生成 URL),而无需修改大量的静态文件。

这些只是静态文件的基础 ,下一节我们来学习如何自定义 Django 自动生成后台网页的过程。

编写你的第一个 Django 应用,第 6 部分相关推荐

  1. 编写你的第一个 Django 应用,第 3 部分

    Hello,我是 Alex 007,一个热爱计算机编程和硬件设计的小白,为啥是007呢?因为叫 Alex 的人太多了,再加上每天007的生活,Alex 007就诞生了. Django视图+模板系统+U ...

  2. 编写你的第一个 Django 应用,第 1 部分

    Hello,我是 Alex 007,一个热爱计算机编程和硬件设计的小白,为啥是007呢?因为叫 Alex 的人太多了,再加上每天007的生活,Alex 007就诞生了. 编写你的第一个 Django ...

  3. 编写你的第一个 Django 应用,第 2 部分

    Hello,我是 Alex 007,一个热爱计算机编程和硬件设计的小白,为啥是007呢?因为叫 Alex 的人太多了,再加上每天007的生活,Alex 007就诞生了. 投票应用程序,第 2 部分 我 ...

  4. django 1.8 官方文档翻译: 1-2-6 编写你的第一个Django应用,第6部分

    编写你的第一个Django应用,第6部分 本教程上接教程 5. 我们已经建立一个测试过的网页投票应用,现在我们将添加一张样式表和一张图片. 除了由服务器生成的HTML文件外,网页应用一般需要提供其它必 ...

  5. django 1.8 官方文档翻译: 1-2-5 编写你的第一个Django应用,第5部分

    编写你的第一个Django应用,第5部分 本教程上接教程第4部分. 我们已经建立一个网页投票应用,现在我们将为它创建一些自动化测试. 自动化测试简介 什么是自动化测试? 测试是检查你的代码是否正常运行 ...

  6. django 1.8 官方文档翻译: 1-2-4 编写你的第一个Django应用,第4部分

    编写你的第一个 Django 程序 第4部分 本教程上接 教程 第3部分 .我们将 继续开发 Web-poll 应用并且关注在处理简单的窗体和优化我们的代码. 编写一个简单的窗体 让我们把在上一篇教程 ...

  7. django 1.8 官方文档翻译: 1-2-3 编写你的第一个Django应用,第3部分

    编写你的第一个 Django 程序 第3部分 本教程上接 教程 第2部分 .我们将继续 开发 Web-poll 应用并且专注在创建公共界面 – "视图 (views )". 哲理 ...

  8. django 1.8 官方文档翻译: 1-2-2 编写你的第一个Django应用,第2部分

    编写你的第一个 Django 程序 第2部分 本教程上接 教程 第1部分 . 我们将继续开发 Web-poll 应用,并且专注在 Django 的 自动生成的管理网站上. 哲理 为你的员工或客户生成添 ...

  9. django 1.8 官方文档翻译: 1-2-1 编写你的第一个Django应用,第1部分

    编写你的第一个 Django 程序 第1部分 让我们通过例子来学习. 在本教程中,我们将引导您创建一个基本的投票应用. 它将包含两部分: 一个公共网站,可让人们查看投票的结果和让他们进行投票. 一个管 ...

  10. [Django个人网站开发]·编写你的第一个 Django 应用-第 1 部分

    编写你的第一个 Django 应用-第 1 部分 让我们通过示例来学习. 通过这个教程,我们将带着你创建一个基本的投票应用程序. 它将由两部分组成: 一个让人们查看和投票的公共站点. 一个让你能添加. ...

最新文章

  1. 谈谈职业规划——CSDN对我的采访
  2. 中小型研发团队架构实践:高效率、低风险,一键发布并测试的持续集成工具Jenkins...
  3. python录制视频和声音_python录制系统声音
  4. java 代码块的作用_Java核心(三):代码块的作用
  5. 史上最详细Docker安装Redis (含每一步的图解)实战
  6. Leetcode 930:和相同的二元子数组
  7. 从安装、管理到防御,阿里云安骑士全向测评
  8. python工作目录,如何使用python 3获取当前工作目录?
  9. Mapreduce和Yarn概念,参数优化,作用,原理,MapReduce计数器 Counter,MapReduce 多job串联之ControlledJob(来自学习资料)...
  10. OpenCV和OpenGL的异同
  11. HazeOver For Mac(管理窗口工具)
  12. css定义文字加粗,css文字加粗font-weight
  13. 一文搞懂如何使用STM32驱动直流电机(普通PWM输出和L298N、高级定时器输出带死区双通道互补PWM和IR2110S及自举电路、H桥电路和电机正反转)
  14. 计算机取消健,电脑取消撤销快捷键是什么_电脑健盘中的所有英文组合意思超值解释建议收藏......
  15. 基于html+css的音乐网站网页设计
  16. android 802.1x 认证,802.1X认证基础
  17. 全国计算机等级三级网络技术试卷详解(三)
  18. 文本分类实战----数据处理篇----embeddings与vocab中词汇不相覆盖问题的处理办法
  19. Giant Sequoia(UTPC Contest 02-25-22 Div. 2 (Beginner))
  20. Sqoop技术—安装及使用教程

热门文章

  1. python中的浅拷贝与深拷贝——copy()
  2. 魔兽 如何屏蔽F1键弹出帮助菜单
  3. UML实践---用例图、顺序图、状态图、类图、包图、协作图
  4. 到你是你玩互联网还是互联网玩了你
  5. 【黑马程序员】————预处理指令1-宏定义
  6. GIS数据格式整理之Coverage篇
  7. 27 款经典的CSS 框架
  8. matlab车辆贪心作业调度,贪心算法-区间调度-Interval Scheduling
  9. 计算机位数与内存相关,弄懂电脑的各种位数、内存、存储
  10. css怎么使元素绝对定位有过度效果_小猿圈web前端讲解div+css绝对定位和相对定位...