Django2.0——模板渲染(一)
在前面的介绍中我们都是用简单的 django.http.HttpResponse来把内容显示到网页上,本节将讲解如何使用渲染模板的方法来显示内容,即调用精美的HTML页面。模板的创建既可以在项目下创建一个templates目录来存放模板,也可以在app应用中新建一个templates文件夹来存放各个模板。
模板配置
要注意的是不管是以哪种方式创建,都要记得在settings中进行配置,不然在调用视图函数时是找不到你指定的是哪个模板。如果是在项目下创建的模板目录,则在settings中的TEMPLATES中的DIRS进行配置,输入创建模板的路径。如果是在app应用中创建的模板,把 app名 加入到 settings.INSTALLED_APPS中。
项目下的templates配置

app下的templates的配置

模板渲染
模板渲染利用的是django.shortcuts.render方法,放在视图函数的return语句中。render方法的第一个参数是request关键字,第二个参数是模板的路径,第三个可选参数是context,以字典的格式作为参数传递给模板,模板可以通过模板变量来接收,模板变量在下面会介绍。
注意:我们一般将模板放在app下的templates中,Django会自动去这个文件夹中找。但 假如我们每个app的templates中都有一个 index.html,当我们在views.py中使用的时候,直接写一个 render(request, 'index.html'),Django 能不能找到当前 app 的 templates 文件夹中的 index.html 文件夹呢?(答案是不一定能,有可能找错)下面介绍下模板的查找机制是怎样的。
Django 模板查找机制: Django 查找模板的过程是在每个 app 的 templates 文件夹中找(而不只是当前 app 中的代码只在当前的 app 的 templates 文件夹中找)。各个 app 的 templates 形成一个文件夹列表,Django 遍历这个列表,一个个文件夹进行查找,当在某一个文件夹找到的时候就停止,所有的都遍历完了还找不到指定的模板的时候就是 Template Not Found (过程类似于Python找包)。这样设计有利当然也有弊,有利是的地方是一个app可以用另一个app的模板文件,弊是有可能会找错了。所以我们使用的时候在 templates 中建立一个 app 同名的文件夹,这样就好了。即在每个app中的 templates 文件夹中再建一个 app 的名称,仅和该app相关的模板放app/templates/app/ 目录下面。
下面在music这个app中实现模板的渲染,首先在music下创建一个目录templates及其子目录music来存放一个模板index.html,再在settings文件中进行配置,再在视图文件中写一个视图函数利用render方法来调用这个模板。




模板变量
模板变量用来接收视图函数传来的值,传来的是一个字典格式。字典中的key在模板中充当变量名,value可以是字典、模型、函数、列表、类方法等。在模板中,变量加点有着特殊的含义,其表示查找。故若传来value是一个字典或列表,可以通过变量.key或变量.下标来取特定的值。
模板变量的语法规则: {{ 变量名 }} 。
下面举一个小例子,传递一个列表和一个字典,然后再模板中分别取一个展示。



模板过滤器
作用: 对变量进行过滤。在真正渲染出来之前,过滤器会根据功能处理好变量,然后得出结果后再替换掉原来的变量展示出来。
语法规则:{{ 变量名|过滤器:参数 }} ,变量名与过滤器通过管道符|分隔开,过滤器的参数与过滤器通过冒号分隔。
下图是一些常用过滤器的总结。

注意:default无论是真的None还是空字符,都会返回一个False,而default_if_none在变量真的为None时才会返回False,然后使用提供的默认值。
date和time的格式化字符如下图所示:

下面的小例子是时间的过滤



floatformat过滤器用于过滤浮点型数据,默认保留一位小数,也可以指定保留小数的个数。
safe过滤器用于关闭变量的自动转义,变量的自动转义就是将<、>、&、空格等转为前端的特殊字符。
Django2.0——模板渲染(一)的更多相关文章
- django2.0模板相关设置
看到了django的模板有include标签 include 标签 {% include %} 标签允许在模板中包含其它的模板的内容. 下面这个例子都包含了 nav.html 模板: {% inclu ...
- 《玩转Django2.0》读书笔记-编写URL规则
<玩转Django2.0>读书笔记-编写URL规则 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. URL(Uniform Resource Locator,统一资源定位 ...
- 《玩转Django2.0》读书笔记-Django建站基础
<玩转Django2.0>读书笔记-Django建站基础 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.网站的定义及组成 网站(Website)是指在因特网上根据一 ...
- Django2.0路由层-URLconf
目录 DJango2.0路由层-URLconf 概述 urlpatterns 实例 path转换器 自定义path转换器 使用正则表达式 命名组(有名分组) URLconf匹配请求URL中的哪些部分 ...
- Django2.0使用
创建项目: 通过命令行的方式:首先要进入到安装了django的虚拟环境中.然后执行命令: django-admin startproject [项目的名称] 这样就可以在当前目录下创建一个项目了. 通 ...
- python Django教程 之模板渲染、循环、条件判断、常用的标签、过滤器
python3.5 manage.py runserver python Django教程 之模板渲染.循环.条件判断.常用的标签.过滤器 一.Django模板渲染模板 1. 创建一个 zqxt_tm ...
- 出位的template.js 基于jquery的模板渲染插件
找了好几款基于jquery的模板渲染插件,无一感觉很难用(教程较少.绑定不统一),也可能我智商问题,比如jquery template.js .jtemplate.js. 然后在github上找到这一 ...
- thinkphp3.2.3模板渲染支持三元表达式
thinkphp3.2.3模板渲染支持三元表达式 {$status?'正常':'错误'} {$info['status']?$info['msg']:$info['error']} 注意:三元运算符中 ...
- Django模板渲染
一 . 语法 # 关于模板渲染只需要记住两种语法就可以: 1.{{ }} # 里面写变量 2.{% %} # 里面写与逻辑相关的,比如for循环 二 . 变量名 在django的模板语言中按照语法: ...
随机推荐
- @Resource 和@Autowired区别
@Autowired 该注解是由spring提供的 按照类型注入 public class UserService { @Autowired private UserDao userDao; } 这样 ...
- vim快速跳转到某一行
在vim命令行模式下输入 : n(行数) |
- 洛谷 P3133 [USACO16JAN]Radio Contact G
题目传送门 解题思路: f[i][j]表示FJ走了i步,Bessie走了j步的最小消耗值.方程比较好推. 横纵坐标要搞清楚,因为这东西WA了半小时. AC代码: #include<iostrea ...
- nodejs —— 流追加数据
在写入流的文档后添加 ,{ 'flags': 'a' } 即可 : var fs = require('fs') var readerStream ...
- 小程序地图开发周边信息POI展示为列表
##首先附上效果图 在我前面的文章中我详述过如何使用百度地图API来开发小程序的地图,所以这里面就不说基础内容了. 直说如下: ##1.如何获取列表: //分类存储 makertap: functio ...
- [LeetCode] 932. Beautiful Array 漂亮数组
For some fixed N, an array A is beautiful if it is a permutation of the integers 1, 2, ..., N, such ...
- 四十五、SAP中Message的管理
一.事务代码SE91 二.输入相关名字,点击创建 三.输入内容 四.定义成本地对象 五.在消息中添加一条短文本 六.我们代码如下 七.执行
- 二十八、SAP中通过以字段以表格形式输出
一.重点在与表格长度的计算,以及LINE-SIZE的用法,代码如下 二.输出效果如下
- 3.2Adding custom methods to mappers(在映射器中添加自定义方法)
3.2Adding custom methods to mappers(在映射器中添加自定义方法) 有些情况下,我们需要实现一些MapStruct无法直接自动生成的复杂类型间映射.一种方式是复用其他已 ...
- 面试题(9)之 leetcode-189
题目描述 解法一: /** * @param {number[]} nums * @param {number} k * @return {void} Do not return anything, ...