18.4 创建其他网页 制定创建网页的流程后,可以开始扩充“学习笔记”项目了。我们将创建两个显示数据的网 页,其中一个列出所有的主题,另一个显示特定主题的所有条目。...对于每个网页,我们都将指定 URL模式,编写一个视图函数,并编写一个模板。但这样做之前,我们先创建一个父模板,项目 中的其他模板都将继承它。...父模板 我们首先来创建一个名为base.html的模板,并将其存储在index.html所在的目录中。这个文件 包含所有页面都有的元素;其他的模板都继承base.html。...下面演示了如何在这个模板 中显示主题: topics.html {% extends "learning_logs/base.html" %} {% block content %} ...同样,我们将定义一个新的URL模式,编写一个视图并创建一个模板。我们还将修改显示所 有主题的网页,让每个项目列表项都是一个链接,单击它将显示相应主题的所有条目。 1.
接下来,我们开始定义一个显示每个条目的项目列表(见2),并像前面显示所有主题一样遍历 条目(见3)。 每个项目列表项都将列出两项信息:条目的时间戳和完整的文本。...为列出时间戳(见4), 我们显示属性date_added的值。在Django模板中,竖线(|)表示模板过滤器——对模板变量的值 进行修改的函数。...将显示所有主题的页面中的每个主题都设置为链接 在浏览器中查看显示特定主题的页面前,我们需要修改模板topics.html,让每个主题都链接 到相应的网页,如下所示: topics.html...现在,主题列 表中的每个主题都是一个链接,链接到显示相应主题的页面,如http://localhost:8000/topics/1/。...你制定了简要的项目规 范,在虚拟环境中安装了Django,创建了一个项目,并核实该项目已正确地创建。你学习了如何 创建应用程序,以及如何定义表示应用程序数据的模型。
base.html,因此其基本结构与项目“学习笔记”的其他页面相同。...在3处,我们显示表单,从中可知Django使得完 成显示表单等任务有多简单:我们只需包含模板变量{{ form.as_p }},就可让Django自动创建显 示表单所需的全部字段。...小部件(widget)是一个HTML表单元素,如单行文本框、 多行文本区域或下拉列表。通过设置属性widgets,可覆盖Django选择的默认小部件。...调用save()时,我们传递了实参commit=False(见5),让Django创建一个新的条目对象,并 将其存储到new_entry中,但不将它保存到数据库中。...在7处,我们将用户重定向到显示相关主题的页面。调用reverse()时,需要提供两个实参: 要根据它来生成URL的URL模式的名称;列表args,其中包含要包含在URL中的所有实参。
下面演示了如何在这个模板中显示主题: {% extends "learning_logs/base.html" %} {% block content %} Topics {...同样,我们将定义一个新的URL模式,编写一个视图并创建一个模板。我们还将修改显示所有主题的网页,让每个项目列表项都是一个链接,单击它将显示相应主题的所有条目。...三 总结 在本章中,我们首先学习了如何使用Django框架来创建Web应用程序。制定了简要的项目规范,在虚拟环境中安装了Django,创建了一个项目,并核实该项目已正确地创建。...学习了如何创建应用程序,以及如何定义表示应用程序数据的模型。学习了数据库,以及在修改模型后,Django可为迁移数据库提供什么样的帮助。...学习了如何创建可访问管理网站的超级用户,并使用管理网站输入了一些初始数据。还探索了Django shell,它让能够在终端会话中处理项目的数据。
context 字典中元素的键值 "hello" 对应了模板中的变量 "{{ hello }}"。...每一次循环中,模板系统会渲染在 {% for %} 和 {% endfor %} 之间的所有内容。...例如,给定一个运动员列表 athlete_list 变量,我们可以使用下面的代码来显示这个列表: {% for athlete in athlete_list %} {{ athlete.name...所有的 {% block %} 标签告诉模板引擎,子模板可以重载这些部分。...hello.html 中继承 base.html,并替换特定 block,hello.html 修改后的代码如下: {% extends "base.html" %} {% block mainbody
,模板引擎发现了 {% extends %} 标签,模板引擎立即装载其父模板,即本例中的 base.html 。...此时,模板引擎注意到 base.html 中的三个 {% block %} 标签,并用子模板的内容替换这些 block 。...在这个模式中, Model 代表数据存取层,View 代表的是系统中选择显示什么和怎么显示的部分,Controller 指的是系统中根据用户输入并视需要访问模型,以决定使用哪个视图的那部分。 ...该层处理与表现相关的决定: 如何在页面或其他类型文档中进行显示。 V:代表视图(View),即业务逻辑层。 该层包含存取模型及调取恰当模板的相关逻辑。 你可以把它看作模型与模板之间的桥梁。 ...普通的活跃,非超级用户的管理用户可以根据一套设定好的许可进入。 管理界面中每种可编辑的对象(如:books、authors、publishers)都有三种权限:创建许可,编辑许可和删除许可。
在本节中,我将简要地介绍应用程序django-bootstrap3,并演示如何将其继承到项目中,为 部署项目做好准备。...图20-1显示了对base.html应用这个Bootstrap模板并对index.html做细微修改后的主页。 知道要获得的效果后,接下来的内容理解起来将更容易。...在6处,我们使用了django-bootstrap3的一个自定义模板标签,它让Django包含所有的 Bootstrap样式文件。...接下来的标签启用你可能在页面中使用的所有交互式行为,如可折叠的导航 栏。7处为结束标签。 2....这个链接是直接从base.html的前一个版本中复制而来的。 在7处,我们添加了第二个导航链接列表,这里使用的选择器为navbar-right。
这个实参让Django创建一个表单,并使用既有条目对象中的信息填充它。 用户将看到既有的数据,并能够编辑它们。...我们将创建一个新的应用程序,其中包含与处理用户账户相关的所有功能。我们还将对模型 Topic稍做修改,让每个主题都归属于特定用户。...base.html,旨在确保登录页面的外观与网站的其他页面相同。...登录视图 将一个表单发送给模板,在模板中,我们显示这个表单(见3)并添加一个提交按钮(见4)。...链接到登录页面 下面在base.html中添加到登录页面的链接,让所有页面都包含它。
命令行工具来自动创建数据库表: manage.py syncdb syncdb 命令会查找你所有可用的模型(models)然后在你的数据库中创建还不存在的数据库表。...在一个创建 Django 应用的典型工作流中,首先需要创建模型并尽可能快地启动和运行 admin sites, 让您的员工(或者客户)能够开始录入数据。然后,才开发展现数据给公众的方式。...编写你的视图(views) 每个视图只负责两件事中的一件:返回一个包含请求页面内容的 HttpResponse 对象; 或抛出一个异常如 Http404 。至于其他就靠你了。...在你的 Django设置中,你可以指定一个查找模板的目录列表。如果一个模板没有在这个 列表中,那么它会去查找第二个,然后以此类推。 假设找到了模板 news/year_archive.html 。...您可以使用其他数据库抽象层,您可以读取 XML 文件,你可以从磁盘中读取文件,或任何你想要的方法去操作数据。 Django 的每个组成部分: 模型、视图和模板都可以解耦,以后会谈到。
但是在Django中,控制器接受用户输入的部分由框架自行处理,所以Django 里更关注的是模型(Model)、模板(Template)和视图(Views),称为MTV模式。...1.1 Django的结构模型 层次 职责 模型(Model)数据存取层 处理与数据相关的所有事务: 如何存取、如何验证有效性、包含哪些行为以及数据之间的关系等。...视图(View)表现层 处理与表相关的决定: 如何在页面或其他类型文档中进行显示。 模板(Template),业务逻辑层 存取模型及调取恰当模板的相关逻辑。模型与模板的桥梁。...ORM,即Object-Relational Mapping(对象关系映射),它的作用是在关系型数据库和业务实体对象之间作一个映射,这样,我们在具体的操作业务对象的时候,就不需要再去和复杂的SQL语句打交道...4.5 启用django 访问admin后台 填充相关的信息 5.配置相关的模板 5.1 配置app的模板 1.把模板的index.html放到templates里面 2.模板的css,js,images
有了这些设置后,运行命令manage.py migrate将为auth相关模型创建必要的数据库表,并为已安装的应用程序中定义的任何模型创建权限。 Django提供以下基于类的视图来处理身份验证。...urls.py,并将其添加到您的文件中。...我们已将帐户应用程序放置在INSTALLED_APPS设置的顶部,以便Django默认使用我们的模板,而不使用其他应用程序中定义的任何身份验证模板。...您需要在注册文件夹之外创建该文件,只需要在主模板中添加该文件,这些就是我们要添加到模板文件夹中的文件。 基本上,home.html用于重定向成功的登录。 这是base.html <!...视图PasswordResetConfirmView会设置此变量,并将其放在password_reset_confirm.html模板的上下文中。 如果链接有效,则显示用户密码重置表格。
如果提交的数据有效,我们就调用表单的方法save(),将用户名和密码的散列值保存到数据 库中(见4)。方法save()返回新创建的用户对象,我们将其存储在new_user中。...如果用户名和密码无误,方法 authenticate()将返回一个通过了身份验证的用户对象,而我们将其存储在authenticated_user 中。...注册模板 注册页面的模板与登录页面的模板类似,请务必将其保存到login.html所在的目录中: register.html {% extends "learning_logs/base.html...全面限制对项目“学习笔记”的访问 Django让你能够轻松地限制对页面的访问,但你必须针对要保护哪些页面做出决定。最好先 确定项目的哪些页面不需要保护,再限制对其他所有页面的访问。...你可以轻松地修改过于严格的 访问限制,其风险比不限制对敏感页面的访问更低。 在项目“学习笔记”中,我们将不限制对主页、注册页面和注销页面的访问,并限制对其他 所有页面的访问。
如果您有过使用其他模版语言的经验,像是 Smarty 或者 Jinja2, 那么您将对Django的模版语言感到一见如故。...如果两个列表都是空的,将显示 “No athletes.” 。...Don't do this. #} 这并不影响来源于模板自身的数据。模板内容在必要时仍然会自动转移,因为它们不受模板作者的控制。 访问方法调用 大多数对象上的方法调用同样可用于模板中。...这意味着模板必须拥有对除了类属性(像是字段名称)和从视图中传入的变量之外的访问。例如,Django ORM提供了“entry_set” 语法用于查找关联到外键的对象集合。...所以,提供一个模型叫做“comment”,并带有一个关联到 “task” 模型的外键,你就可以遍历给定任务附带的所有评论,像这样: {% for comment in task.comment_set.all
一、路由系统 在settings.py文件中通过ROOT_URLCONF指定根级url的配置 urlpatterns是一个url()实例的列表 一个url()对象包括: 正则表达式 视图函数 名称name...中的路由系统和其他语言的框架有所不同,在django中每一个请求的url都要有一条路由映射,这样才能将请求交给对一个的view中的函数去处理。...,该语言可以实现数据展示 1 列表,字典,类的实例的使用 2 3 循环:迭代显示列表,字典等中的内容 4 5 条件判断:判断是否显示该内容,比如判断是手机访问,还是电脑访问,给出不一样的代码。... {% block content %} 这里是默认内容,所有继承自这个模板的,如果不覆盖就显示这里的默认内容。...其它的页面继承自 base.html 就好了,继承后的模板也可以在 block 块中 include 其它的模板文件。
继上篇 django2实战3.模型的增删改查 我们已经知道如何操作文章表的数据,接下来要将这些数据用界面显示出来。...这就需要用到django的view层负责处理http请求,并将数据传给template模板进行渲染 url适配 首先定义列表页与详情页的url, url规则如下: 列表页:http://127.0.0.1...()就能获取所有已发布的文章 在view中写业务逻辑 mysite/blog/views.py from django.shortcuts import render, get_object_or_404...,列表页和详情页都继承此文件 list.html 列表页,展示文章标题、摘要 detail.html 详情页,展示文章详情内容 html模板引用 Bootstrap4 base.html {% load..., 并将内容注入到base.html中id为content的div中 detail.html {% extends "blog/base.html" %} {% block title %}{{ post.title
%},那么模板中就会有一个从数据库获取的最新文章列表,并通过 as 语句保存到 recent_post_list 模板变量里。...首页视图函数中从数据库获取文章列表并保存到 post_list 变量,然后把这个 post_list 变量传给模板,模板使用 for 模板标签循环这个文章列表变量,从而展示一篇篇文章。...,列表中的元素为每一篇文章(Post)的创建时间,且是 Python 的 date 对象,精确到月份,降序排列。....设计评论的数据库模型 用户评论的数据必须被存储到数据库里,以便其他用户访问时 Django 能从数据库取回这些数据然后展示给访问的用户,因此我们需要为评论设计数据库模型,这和设计文章、分类、标签的数据库模型是一样的...和处理 index 页面的文章列表方式是一样的,我们在模板中通过 {% for %} 模板标签来循环显示文章对应的全部评论内容。
Django 框架的核心组件有: 用于创建模型的对象关系映射 为最终用户设计的完美管理界面 一流的 URL 设计 设计者友好的模板语言 缓存系统 本文是有关 Python Web 框架的由两篇文章组成的系列文章的第一篇...Django 在 Admin 工具中显示对象时广泛地使用了这个方法。 要设置这个模型的模式,请返回 manage.py 的 sql 命令。此时模式尚未确定。 清单 10....例如,要打印所有 Job 的列表,则应该使用 objects 管理器的 all 方法: 清单 11....该模板是使用名为 object_list 的职位列表的上下文呈现的。所呈现的模板字符串随后被传递到 HTTPResponse 构造器中,后者通过这个框架被发送回请求客户机那里。...站点非常有用) 对象的创建、更新和删除(CRUD) 简单直接的模板表示或简单地对 HTTP 重新进行定向 我们没有创建样板视图方法,而是将所有的业务逻辑都放入了 urls.py 文件中,它们都由 Django
这是 Django 规定的语法。用 {{ }} 包起来的变量叫做模板变量。Django 在渲染这个模板的时候会根据我们传递给模板的变量替换掉这些变量。最终在模板中显示的将会是我们传递的值。...最终,我们的 HTML 模板中的内容字符串被传递给 HttpResponse 对象并返回给浏览器(Django 在 render 函数里隐式地帮我们完成了这个过程),这样用户的浏览器上便显示出了我们写的...接着如之前所做,我们渲染了 blog\index.html 模板文件,并且把包含文章列表数据的 post_list 变量传给了模板。...这里面包裹的内容显示的就是文章数据了。我们前面在视图函数 index 里给模板传了一个 post_list 变量,它里面包含着从数据库中取出的文章列表数据。...就像 Python 一样,我们可以在模板中循环这个列表,把文章一篇篇循环出来,然后一篇篇显示文章的数据。要在模板中使用循环,需要使用到前面提到的模板标签,这次使用 {% for %} 模板标签。
请尝试调整窗口的大小,使其非常窄;此时导航栏将变成一个按钮,如果你单击这个按钮,将打 开一个下拉列表,其中包含所有的导航链接。...jumbotron 元素是一个大框,相比于页面的其他部分显得鹤立鸡群,你想在其中包含什么东西都可以;它通 常用于在主页中呈现项目的简要描述。我们还可以修改主页显示的消息。...然后,我们删除了这个模板中以前使用的无序 列表结构。...注意,只修改了影响页面外观的元素,对在 页面中包含信息的Django代码未做任何修改。 图20-3显示了修改后的topic页面。...注意 要使用其他Bootstrap模板,可采用与本章类似的流程:将这个模板复制到base.html中,并 修改包含实际内容的元素,以使用该模板来显示项目的信息;然后,使用Bootstrap的样 式设置工具来设置各个页面中内容的样式
、并返回一个渲染后的HttpResponse对象 参数: request:用于生成响应的请求对象。...每个模板只包含对自己而言 独一无二 的代码。 无需多余的部分。 如果想进行站点级的设计修改,仅需修改 base.html ,所有其它模板会立即反映出所作修改。...模板引擎立即装载其父模板,即本例中的 base.html 。此时,模板引擎注意到 base.html 中的三个 {% block %} 标签,并用子模板的内容替换这些 block 。...这些模板对base.html 进行拓展, 并包含区域特定的风格与设计。 为每种类型的页面创建独立的模板,例如论坛页面或者图片库。 这些模板拓展相应的区域模板。...这个方法可最大限度地重用代码,并使得向公共区域(如区域级的导航)添加内容成为一件轻松的工作。
领取专属 10元无门槛券
手把手带您无忧上云