Django 2.0.1 官方文档翻译:编写你的第一个 Django app,第六部分(Page 11)
编写你的第一个 Django app,第六部分(Page 11)转载请注明链接地址
本教程上接前面第五部分的教程。我们构建了一个经过测试的 web-poll应用,现在我们会添加一个样式表和一张图片。
除了服务器上生成的HTML,web应用一般需要其他文件 —— 例如图片,JavaScript,或CSS —— 渲染完整的web页面所必须的内容。在Django中,我们引用的这些文件称为“静态文件”。
对于小的项目,这没有什么大不了。因为你只要将这些静态文件保存到你的web服务器可以找到的地方就可以了。然而在比较大的项目中 —— 尤其有多个app组成的项目中 —— 处理多个应用提供的静态文件集合会变得很棘手。
这正是 django.contrib.staticfiles
的用途: 它从将每个应用收集到的静态文件集中到一个在生产环境中容易维护的单独的位置(意思就是把静态文件收集起来,放到一个指定的位置,这个位置为可以方便项目使用)。
自定义你的应用的外观
首先,在polls
应用的目录下创建一个名为static
目录。Django从这里查找静态文件,和Django在polls/templates/
中查找模板一样。
Django 的STATICFILES_FINDERS
(这里少一个链接)设置包含一个查找器列表,它知道如何从多个源中发现静态文件。默认的一个是AppDirectoriesFinder
,它会在每个INSTALLED_APPS
(这里少一个链接)中查找“static”子目录,就像查找我们刚刚在polls
中创建的“static”一样。admin站点为它的静态文件使用相同的目录结构。
在你刚刚创建的static
目录中,创建另外一个名字是polls
的目录,并在它下面创建一个名字是 style.css
的文件。也就是说,你的样式表文件应该被放在 polls/static/polls/style.css
。由于AppDirectoriesFinder
静态文件查找器的工作方式,你可以在django中以polls/style.css
的方式应用这个静态文件,与你引用模板的路径类似。
静态文件命名空间
就像模板一样,我们可以直接将惊天文件放入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 %}
<link rel="stylesheet" type="text/css" href="{% static 'polls/style.css' %}" />
{% static %}
模板标签会生成静态文件的绝对路径。
这就是你在开发中需要做的所有事情。重新打开http://localhost:8000/polls/
,你会看到question的链接是绿色的(django的样式),这表示你的样式表被正确的加载了。
添加一张背景图片
下一步,我们会为图片创建一个子目录。在polls/static/polls/
目录创建一个images
子目录。在这个目录里,放一张名字是background.gif
的图片。也就是说,把你的图片放在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 right bottom;
}
重新打开http://localhost:8000/polls/
,你会看到在屏幕的右下角加载了一张背景图片。
注意
{% static %}
模板标签在不是通过django生成的静态文件中是无效的(意就是说{% static %}
是django自己用的)。你应该使用相对路径将你的静态文件链接起来,因为这样你就可以修改STATIC_URL
(这里少一个链接)(静态模板标签(static template tag
(这里少一个链接))用来生成它的URLs)而不用修改许多静态文件中的路径。
这些都是基础知识,更多关于设置和其他细节的内容请查看 the static files howto
(这里少一个链接) 和 the staticfiles reference
(这里少一个链接)。Deploying static files
(这里少一个链接) 讨论如何在真是的服务器上使用静态文件。
如果你已经熟悉了静态文件,就可以开始学习下一节内容了:如何自定义django自动生成的admin站点(page 12)。
Django 2.0.1 官方文档翻译:编写你的第一个 Django app,第六部分(Page 11)的更多相关文章
- Django 2.0.1 官方文档翻译: 编写你的第一个 Django app,第一部分(Page 6)
编写你的第一个 Django app,第一部分(Page 6)转载请注明链接地址 Django 2.0.1 官方文档翻译: Django 2.0.1.dev20171223092829 documen ...
- Django 2.0.1 官方文档翻译: 编写你的第一个 Django app,第五部分(Page 10)
编写你的第一个 Django app,第五部分(Page 10)转载请注明链接地址 我们继续建设我们的 Web-poll 应用,本节我们会为它创建一些自动测试. 介绍自动测试 什么是自动测试 测试是简 ...
- Django 2.0.1 官方文档翻译: 编写你的第一个 Django app,第二部分(Page 7)
编写你的第一个 Django app,第二部分(Page 7)转载请注明链接地址 本教程上接前面的教程.我们会配置数据,创建你的第一个 model,并对Django 自动生成的 admin 站点进行快 ...
- Django 2.0.1 官方文档翻译: 编写你的第一个 Django app,第七部分(Page 12)
编写你的第一个 Django app,第七部分(Page 12)转载请注明链接地址 本节教程承接第六部分(page 11)的教程.我们继续开发 web-poll应用,并专注于自定义django的自动生 ...
- Django 2.0.1 官方文档翻译: 编写你的第一个 Django app,第四部分(Page 9)
编写你的第一个 Django app,第四部分(Page 9)转载请注明链接地址 该教程上接前面的第三部分.我们会继续开发 web-poll 应用,并专注于简单的表单处理和简化代码. 写一个简单的表单 ...
- Django 2.0.1 官方文档翻译: 编写你的第一个 Django app,第三部分(Page 8)
编写你的第一个 Django app,第三部分(Page 8)转载请注明链接地址 本页教程接前面的第二部分.我们继续开发 web-poll app,我们会专注于创建公共接口上 -- "视图& ...
- Django 2.0.1 官方文档翻译:编写你的第一个djang补丁(page 15)
编写你的第一个djang补丁(page 15) 介绍 有兴趣为社区做一些贡献?可能你发现了django中的一个你想修复的bug,或者你你想添加一个小小的功能. 回馈django就是解决你遇到的问题的最 ...
- Django 2.0.1 官方文档翻译: 高级教程:如何编写可重用的app (page 13)
高级教程:如何编写可重用的app (page 13) 本节教程上接第七部分(Page 12).我们会把我们的 web-poll应用转换成一个独立的python包,你可以在新的项目中重用或者把它分享给其 ...
- Django 2.0.1 官方文档翻译: 如何安装 django (Page 17)
如何安装 django(Page 17) 这一部分可以让你将 Django 运行起来. 安装 Python 作为 python 的一个 web 框架,Django 依赖 Python.Python 的 ...
随机推荐
- 学习总结:jQuery插件开发模式和结构
学习博客链接: ①https://www.cnblogs.com/cyStyle/ ② https://www.cnblogs.com/chengyunshen/p/7277305.html ③ ht ...
- 20_集合_第20天(Map、可变参数、Collections)_讲义
今日内容介绍 1.Map接口 2.模拟斗地主洗牌发牌 01Map集合概述 A:Map集合概述: 我们通过查看Map接口描述,发现Map接口下的集合与Collection接口下的集合,它们存储数据的形式 ...
- 项目报错“JavaServer Faces 2.2 can not be installed : One or more constraints”等一系列问题
在做springmvc+maven项目时,经常遇到如下错误: 解决办法(这里以jdk1.8,web3.0为例): 一:保证build path的jre版本 remove掉旧版本的,add新版本 二:保 ...
- css border 制作三角形
border 边框 上三角 是只有上面的border 有颜色,其余的边框都是tranparents,下三角只有下面的border 有颜色,其余的边框都是tranparents,左三角只有左面的bord ...
- svmtrain和svmpredict简介
转自:http://blog.sina.com.cn/s/blog_4d7c97a00101bwz1.html 本文主要介绍了SVM工具箱中svmtrain和svmpredict两个主要函数: (1) ...
- PAT 1053 住房空置率
https://pintia.cn/problem-sets/994805260223102976/problems/994805273284165632 在不打扰居民的前提下,统计住房空置率的一种方 ...
- MySQL数据库中varchar与char类型的区别
在数据库中建表时,需要给数据定义一个数据库中的数据库类型,当需要给String类型定义一个数据库中的类型时,可以看见有两个选择,一个是varchar,另一个是char,有很多人不清楚两者的区别,包括自 ...
- ZOJ3435_Ideal Puzzle Bobble
把L,H,W分别减一就变成上面一个题目了. 不多说,也不召唤代码君了.
- STM32CubeMX介绍、下载与安装
一.简介 STM32CubeMX是一个配置STM32代码的工具,它把很多东西封装的比较好,硬件抽象层.中间层.示例代码等.现在ST公司升级和维护的库主要就是STM32CubeMX的HAL库和标准外设库 ...
- python mysql开发日志
开始做python 的数据库访问了,暂时选定了mysql数据库.原本想使用ORM,后来考虑到项目的情况是:表结构不复杂,但是数据库非常大.还是自己来操作sql,不过PYTHON的那些数据库ORM的代码 ...