Django框架详解之template
模板简介
将页面的设计和python的代码分离开会更干净简洁更容易维护。我们可以使用Django的模板系统来实现这种模式
python的模板:HTML代码+模板语法
模板包括在使用时会被值替换掉的变量,和控制模板逻辑的标签
变量
在Django模板中遍历复杂数据结构的关键是句点字符
{#语法#} {{ var_name }}
views
def index(request):
import datetime
s='hello'
l=[1,2,3]
dic={"name":'lary',"age":18}
date = datetime.date(2000,3,12) class Person(object):
def __init__(self,name):
self.name = name person_l=Person("lily")
person_j=Person('jerry')
person_t=Person('tom') person_li=[person_l, person_j, person_t] return render(request,'index.html',{"l":l,"dic":dic,"date":date,"person_list":person_li,"s":s})
template
<body>
<h4>{{ s }}</h4>
<h4>{{ l.0 }}</h4>
<h4>{{ dic.name }}</h4>
<h4>{{ date.year }}</h4>
<h4>{{ person_list.0.name}}</h4>
{#句点符也可以用来引用对象的方法(无参数方法)#}
<h4>{{ dic.name.upper }}</h4>
模板之过滤器
语法
{{obj|filter_name:param}}
default
如果一个变量是false或者为空,使用给定的默认值。否则,使用变量的值
{{value|default:"nothing"}}
length
返回值的长度。它对字符串和列表都起作用
{{value|length}}
filesizeformat
将值格式化为一个可读的文件尺寸
{{value|filesizeformat}}
date
{#如果value=datetime.datetime.now()#}
{{value|date:"Y-m-d"}}
slice
{#如果value="hello world"#}
{{value|slice:"2:-1"}}
truncatechars
如果字符串多于指定的字符数量,那么会被截断。截断的字符串将以省略号(“...”)结尾
{{value|truncatechars:9}}
safe
Django模板中会对HTML标签和js等语法进行自动转义,这样是为了安全。但是有的时候我们可能不希望这些HTML元素被转义,为了在Django中关闭HTML的自动转义的两种方式,如果是一个单独的变量可以通过"|safe"的方式告诉Django这段代码是安全的不必转义
value="<a href="">点击</a>"
{{value|safe}}
autoescape
控制当前的自动转义行为,此标记采用on或者off作为参数,并确定自动转义是否在块内有效。该块以endautoescape结束标签关闭
def generate_report(request):
report_name = "this is a test report"
report_tilte = "<h1>this is a title</h1>"
return render(request, 'report.html', locals())
开启转义
{% autoescape on %}
{{ report_title }}
{% endautoescape %}
关闭转义,默认该语句块中的内容是安全的
{% autoescape off %}
{{ report_title }}
{% endautoescape %}
模板之标签
标签比变量更加复杂:一些在输出中创建文本,一些通过循环或逻辑来控制流程,一些加载其后的变量将使用到额外信息到模板中,一些变迁需要开始和结束标签
for标签
{#遍历每一个元素#}
<h4>{{ dic.name.upper }}</h4>
{% for person in person_list %}
<p>{{ person.name }}</p>
{% endfor %} {#遍历字典#}
{% for key,val in dic.items %}
<p>{{ key }}:{{ val }}</p>
{% endfor %} {#循环序号#}
{{forloop.counter}}
for...empty
for标签带有一个可选的{% empty%}从句,以便在给出的组是空的或者没有被找到时,可以有所操作
{#for empty#}
{% for person in person_list %}
<p>{{ person.name }}</p>
{% empty %}
<p>sorry,no person here</p>
{% endfor %}
if标签
if标签会对一个变量求值,如果它的值是true,对应的内容块会输出
{#if标签#}
{% if num > 100 or num < 0 %}
<p>无效</p>
{% elif num > 80 and num < 100 %}
<p>优秀</p>
{% else %}
<p>一般</p>
{% endif %}
with
使用一个简单的名字缓存一个复杂的变量,当你需要使用一个方法很多次的时候是非常有用的
{#with标签#}
{% with total=business.employees.count %}
{{ total}}employee{{ tatal|pluralize }}
{% endwith %}
csrf_token
这个标签用于跨站请求伪造保护
{#csrf_token#}
{% csrf_token %}
自定义标签和过滤器
在settings中的INSTALLED_APPS配置当前app
在app中创建templatetags模块
创建任意.py文件,如my_tags.py
from django import template
from django.utils.safestring import mark_safe register = template.Library() @register.filter
def filter_multi(x,y):
return x*y @register.simple_tag
def simple_tag_multi(x,y):
return x*y @register.simple_tag
def my_input(id,args):
result="<input type='text' id='%s' class='%s'/>"%(id,args,)
return mark_safe(result)
在使用自定义simple_tag和fileter的html文件中导入之前创建的my_tag.py
{% load my_tag %}
使用simple_tag和filter
{{ num|filter_multi:2 }}
{{ num|filter_multi:"[22,33,444]" }}
{#参数不限,但不能放在if for语句中#}
{% simple_tag_multi 2 5 %}
{% simple_tag_multi num 5 %} {#filter可以用在if等语句后,simple_tag不可以#}
{% if num|filter_multi:30 > 100 %}
{{ num|filter_multi:30 }}
{% endif %}
Django框架详解之template的更多相关文章
- Django框架详解之url
Django基本命令 下载Django pip3 install django 创建一个django project django-admin.py startproject cms 当前目录下会生成 ...
- Django框架详解
一.WSGI接口 WSGI服务网关接口:Web Server Gateway Interface缩写. WSGI是python定义的Web服务器和Web应用程序之间或框架之间的通用接口标准. WSGI ...
- Django框架详解之views
一个简单的视图 一个视图函数,是一个简单的python函数,它接受web请求并且返回web响应.无论视图本身包含什么逻辑,都要返回响应.为了将代码放在某处,约定是将视图放置在项目或应用程序目录中的名为 ...
- Django -- settings 详解
Django settings详解 1.基础 DJANGO_SETTING_MODULE环境变量:让settings模块被包含到python可以找到的目录下,开发情况下不需要,我们通常会在当前文件夹运 ...
- Django -- settings 详解(转)
Django -- settings 详解 Django settings详解 1.基础 DJANGO_SETTING_MODULE环境变量:让settings模块被包含到python可以找到的目 ...
- Django 2.0 学习(20):Django 中间件详解
Django 中间件详解 Django中间件 在Django中,中间件(middleware)其实就是一个类,在请求到来和结束后,Django会根据自己的规则在合适的时机执行中间件中相应的方法. 1. ...
- jQuery Validate验证框架详解
转自:http://www.cnblogs.com/linjiqin/p/3431835.html jQuery校验官网地址:http://bassistance.de/jquery-plugins/ ...
- mina框架详解
转:http://blog.csdn.net/w13770269691/article/details/8614584 mina框架详解 分类: web2013-02-26 17:13 12651人 ...
- lombok+slf4j+logback SLF4J和Logback日志框架详解
maven 包依赖 <dependency> <groupId>org.projectlombok</groupId> <artifactId>lomb ...
随机推荐
- JS中的map
定义和用法: map() 方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值. map() 方法按照原始数组元素顺序依次处理元素. 注意: map() 不会对空数组进行检测. 注意: m ...
- express+node.js搭建的服务器和在sublimeServer下的页面请求报跨域错误
1.前端页面使用vue中的axios请求nodejs响应.报以下错误: Failed to load http://localhost:3000/users/validate: Response to ...
- Python编码显示中文乱码
爬虫时出现问题: import requests data=requests.get('http://roll.news.sina.com.cn/')print(data.text) 输出结果中文显示 ...
- nyoj212-k尾相等数
212-K尾相等数 内存限制:64MB时间限制:3000msSpecial Judge: No accepted:0submit:0 题目描述: 输入一个自然数K(K>1),如果存在自然数M和N ...
- [luogu2216 HAOI2007] 理想的正方形 (2dST表 or 单调队列)
题目描述 有一个ab的整数组成的矩阵,现请你从中找出一个nn的正方形区域,使得该区域所有数中的最大值和最小值的差最小. 输入输出格式 输入格式: 第一行为3个整数,分别表示a,b,n的值 第二行至第a ...
- JavaScript链式编程模拟Jquery函数
<span>Hello,World!</span> <script type="text/javascript"> Jq = function ...
- 专访Bruce Douglass,谈嵌入式经验
Bruce:表面上看,编程就是想要实现什么就写什么代码:但事实是,敲代码只是软件开发过程中很小的一部分,程序员的工作还包括安全分析.责任分析.产品验证.产品分析等. =========== ...
- 从零開始写游戏引擎(一) - project创建以及文件夹设置还有版本号控制
一句话提要 好的開始等于成功了一半. 创建文件夹结构 project文件夹下最好分为以下几个文件夹 Docs - 开发文档,设计文档 Assets - 角色,动作,模型和音效等 Source - 代码 ...
- 多播 & multicast
参考: http://blog.csdn.net/herbert5069/article/details/31358641
- 建议53:用状态模式美化代码,关于python-state工具包的理解
在<编写高质量代码:改善python程序的91个建议>的建议53:用状态模式美化代码小节中,介绍了状态模式例如以下:就是当一个对象的内在状态改变时,同意改变其行为,但这个对象看起来 ...