Django模板系统:Template
一、模板常用语法
1.1 变量
- 符号:{{ }}
- 表示变量,在模板渲染的时候替换成值
- 使用方式:{{ 变量名 }}:变量名由字母数字和下划线组成
- 点(.)在模板语言中有特殊的含义,用来获取对象的相应属性值
- 注意:当模板系统遇到一个(.)时,会按照如下的顺序去查询:
- 在字典中查询
- 属性或者方法
- 数字索引
1.2 内置filter
filter:过滤器,用来修改变量的显示结果
- 语法: {{ value|filter_name:参数 }}
- ':'左右没有空格没有空格没有空格
内置过滤器
default:默认值
- 语法:{{ value|default:"nothing"}}
- 如果value值没传的话就显示nothing
- 补充:TEMPLATES的OPTIONS可以增加一个选项:string_if_invalid:'找不到',可以替代default的的作用
filesizeformat:文件大小,将值格式化为可读的文件尺寸
- 语法:{{ value|filesizeformat }}
- 如,value=123456789,输出将会是 117.7 MB
add:给变量加参数
- 语法:{{ first|add:second }}
- 优先看是否能转化为数字相加,其次是字符串拼接
- 如果都是列表,相当于extend,循环加入
length:返回长度
- 语法:{{ value|length }}
- 返回value的长度,如,value=['a', 'b', 'c', 'd']的话,就显示4
slice:切片
- 语法:{{value|slice:"2:-1"}}
first / last:取第一个/最后一个元素
- 语法:
- 取第一个元素:{{ value|first }}
- 取最后一个元素:{{ value|last }}
- 语法:
join:使用字符串拼接列表
- 语法:{{ value|join:" // " }}
truncatechars:截断,按照字符计数
- truncatewords:按照字母计数,不能识别中文
- 如果字符串字符多于指定的字符数量,那么会被截断
- 截断的字符串将以可翻译的省略号序列(...)结尾
- 参数:截断的字符
- 语法:{{ value|truncatechars:9}}
date:日期格式化
语法:{{ value|date:"Y-m-d H:i:s"}}
在settings.py中配置:
USE_L10N = False DATETIME_FORMAT = 'Y-m-d H:i:s' # datetime类型
DATE_FORMAT = 'Y-m-d' # date类型
TIME_FORMAT = 'H:i:s' # time类型
配置后,使用{{now}}可以实现日期格式化
- 其中,'now':datetime.datetime.now()
safe:告诉django这段代码是安全的,不需要转义
- 语法:{{ value|safe}}
- 如,
value = "<a href='#'>点我</a>"
1.3 自定义filter
在app下创建一个名为templatetags的python包
在templatetags中创建py文件,文件名自定义(my_tags.py);
在py文件中写:
from django import template
register = template.Library() # register也不能变
写函数+装饰器
@register.filter
def add_xx(value, arg): # 最多有两个
return '{}-{}'.format(value, arg) @register.filter(name='adds') # 相当于更改了函数名,使用时,使用新的函数名
在模板文件中使用,html文件
{% load my_tags %}
{{ 'alex'|add_xx:'dsb' }}
注意:
- 为避免出错,templatetags最好是一个Python包,并且名称不能更改
- register名称也不能更改,必要时需要重启项目
- Python包下的init中可能有其他内容django不能识别,导致出错,可以直接删除内容
1.4 标签tag
符号:{% %}
for循环
<ul>
{% for user in user_list %}
<li>{{ user.name }}</li>
{% endfor %}
</ul>
- forloop:字典形式
Variable Description forloop.counter当前循环的索引值(从1开始) forloop.counter0当前循环的索引值(从0开始) forloop.revcounter当前循环的倒序索引值(到1结束) forloop.revcounter0当前循环的倒序索引值(到0结束) forloop.first当前循环是不是第一次循环(布尔值) forloop.last当前循环是不是最后一次循环(布尔值) forloop.parentloop本层循环的外层循环 - for ... empty
{% for book in all_books %}
<tr>
.....
</tr>
{% empty %}
<td>没有相关的数据</td>
{% endfor %}
if判断
- if语句支持 and 、or、==、>、<、!=、<=、>=、in、not in、is、is not判断
{% if 条件1 %}
xxx
{% elif 条件2 %}
xxx
{% else %}
xxxxx
{% endif %}
- 连续判断
- python中,10>5>1 --> 10>5 and 5>1 --> true
- js中,10>5>1 --> true>1 --> 1>1 --> false
- 模板中,不支持连续连续判断 也不支持算数运算(可使用过滤器)
with:给变量重命名,但只在with区域内生效
{% with hobby.2 as talk %}
{# 相当于 {% with talk=hobby.2 %},其中=两边不能有空格 #}
{{ talk }}
{% endwith %}
csrf_token
- 该标签用于跨站请求伪造保护
- csrf:跨站请求伪造
- 使用方式:在form表单中写上{% csrf_token %}
- 这样就不用在settings中注释含csrf的中间件了
- 该标签用于跨站请求伪造保护
1.5 注释
符号:{# 要注释的内容 #}
快捷键:Ctrl + ?
{# 要注释的内容 #}
二、母板和继承
2.1 母板
母板就是一个普通的html,提取多个页面的公共部分,通过定义block块来实现
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Title</title>
{% block page-css %} {% endblock %}
</head>
<body>
<h1>这是母板的标题</h1>
{% block page-main %} {% endblock %}
<h1>母板底部内容</h1>
{% block page-js %} {% endblock %}
</body>
</html>
block块:
{% block 块名 %} {% endblock %}
注意:我们通常会在母板中定义页面专用的CSS块和JS块,方便子页面替换
2.2 继承
子页面继承母板:{% extends '母板html' %}
{% extends 'layouts.html' %}
子页面通过重写block块,来替换母板中相应的内容
{% block page-main %}
<p>世情薄</p>
<p>人情恶</p>
<p>雨送黄昏花易落</p>
{% endblock %}
2.3 注意
- {% extends 'base.html' %}要写在第一行,前面不要有内容,否则内容会显示出来
- {% extends 'base.html' %}中的'base.html' 必须加上引号,不然会被当做变量去查找
- 子页面把要显示的内容写在block块中,否则不会显示出来
- 多个位置有独特内容,可以定义多个block块,特殊:定义css、js块等
三、组件
组件:一小段html代码段
可以将常用的页面内容如导航条,页尾信息等组件保存在单独的文件中,然后在需要使用的地方导入
{% include 'navbar.html' %}
四、静态文件相关
目的:更改setting中静态文件的别名时,不影响在更改之前的静态文件的引用,即引用会跟随别名的更改而自动更改,这样就不会报错了
方法一:使用static,原本路径:/static/images/hi.jpg
{% load static %}
<img src="{% static "images/hi.jpg" %}" alt="Hi">
- 文件多处被用到可以存为一个变量
{% load static %}
{% static "images/hi.jpg" as myphoto %}
<img src="{{ myphoto }}">
方法二:使用get_static_prefix,原本路径:/static/images/hi.jpg
{% load static %}
<img src="{% get_static_prefix %}images/hi.jpg" alt="Hi"> {# 补充:获取别名 #}
{% get_static_prefix %}
- 文件多处被用到可以存为一个变量
{% load static %}
{% get_static_prefix as STATIC_PREFIX %}
<img src="{{ STATIC_PREFIX }}images/hi.jpg" alt="Hi">
五、自定义simple_tag
和自定义filter类似,区别:接收的参数更灵活,能接收万能参数
定义注册simple_tag
@register.simple_tag
def join_str(*args, **kwargs):
return '{} - {} '.format('*'.join(args), '$'.join(kwargs.values())) @register.simple_tag(name='join') # 相当于更改了函数名,使用时,使用新的函数名
使用自定义simple_tag
{% load my_tags %}
{% join_str '1' '2' k1='3' k2='4' %}
六、inclusion_tag
在app下的templatetags(python包)中创建py文件,文件名自定义(my_inclusion.py);
在py文件中写:
from django import template
register = template.Library() # register也不能变
写函数+装饰器
@register.inclusion_tag('result.html')
# result.html 是内容的html
def show_results(n):
n = 1 if n < 1 else int(n)
data = ["第{}项".format(i) for i in range(1, n+1)]
return {"data": data}
在result.html中写:
<ul>
{% for choice in data %}
<li>{{ choice }}</li>
{% endfor %}
</ul>
在模板文件中使用
{% load my_inclusion %}
{% show_results 10 %}
Django模板系统:Template的更多相关文章
- Django 模板系统(template)
介绍 官方文档 常用模板语法 只需要记两种特殊符号: {{ }} 和 {% %} 变量相关的用{{}} 逻辑相关的用{%%} 变量 {{ 变量名 }} 变量名由字母数字和下划线组成. 点(.)在模 ...
- Django模板(Template)系统
Django模板系统 官方文档 常用语法 只需要记两种特殊符号: {{ }}和 {% %} 变量相关的用{{}},逻辑相关的用{%%}. 变量 {{ 变量名 }} 变量名由字母数字和下划线组成. 点 ...
- django模板系统基础
模板系统基础Django模板是一个string文本,它用来分离一个文档的展现和数据 模板定义了placeholder和表示多种逻辑的tags来规定文档如何展现 通常模板用来输出HTML,但是Djang ...
- Django——模板层(template)(模板语法、自定义模板过滤器及标签、模板继承)
前言:当我们想在页面上给客户端返回一个当前时间,一些初学者可能会很自然的想到用占位符,字符串拼接来达到我们想要的效果,但是这样做会有一个问题,HTML被直接硬编码在 Python代码之中. 1 2 3 ...
- python MVC、MTV 框架介绍 Django 模板系统常用语法
Django 框架简介一.MVC框架和MTV框架1.MVC 全名Model View Controller,是软件工程中的一种软件架构模式,把软件系统分为三个基本部分.优势: 耦合性低 重用性高 生命 ...
- Django 模板系统
Django模板系统 常用语法 {{}} 变量相关 {%%} 逻辑相关 变量 格式 {{ 变量名 }} 命名规则 包括任何字母数字以及下划线 ("_")的组合 变量名称中不能有空格 ...
- Python学习(二十八)—— Django模板系统
转载自http://www.cnblogs.com/liwenzhou/p/7931828.html Django模板系统 官方文档 一.常用语法 只需要记两种特殊符号: {{ }}和 {% %} ...
- Django模板系统(非常详细)(后台数据如何展示在前台)
前面的章节我们看到如何在视图中返回HTML,但是HTML是硬编码在Python代码中的这会导致几个问题:1,显然,任何页面的改动会牵扯到Python代码的改动网站的设计改动会比Python代码改动更频 ...
- (转)Django学习之 第四章:Django模板系统
前面的章节我们看到如何在视图中返回HTML,但是HTML是硬编码在Python代码中的 这会导致几个问题: 1.显然,任何页面的改动会牵扯到Python代码的改动 网站的设计改动会比Python代码改 ...
随机推荐
- JS高阶---语句分号相关
[总结] 小括号和中括号开头的在其前必须加封号: [主体] 首先搜索下 [主体] (1)讨论---编码风格问题 (2)什么情况必须用封号? 1.其后跟着匿名式函数调用 此时可以在匿名函数前加:如下所示 ...
- JS三座大山再学习 ---- 异步和单线程
本文已发布在西瓜君的个人博客,原文传送门 前言 写这一篇的时候,西瓜君查阅了很多资料和文章,但是相当多的文章写的都很简单,甚至互相之间有矛盾,这让我很困扰:同时也让我坚定了要写出一篇好的关于JS异步. ...
- c# 第五节 第一个控制台程序、第一个桌面、快捷键、注释
本节内容: 1:控制台程序的创建 2:第一个桌面程序 3:快捷键 4:注释 一.第一个控制台程序: 这就是控制台程序: 打开你的vs2015,按如下操作 二.第一个桌面程序 比如当我们删除一个东西会弹 ...
- Github实战测试情况
测试情况 很久没有熬夜测试程序了,经过测试,没有复现功能的有echo.葫芦娃.火鸡堂.那周余嘉熊掌将得队.为了交项目而干杯.修!咻咻!.云打印和追光的人.据汪老师反应在现场实践课程中大都能实现的,公平 ...
- Leetcode148-Sort_List
Sort_List 在LeetCode 里面,因为只有归并排序的时间复杂度为O(1),所以快速排序用不了,前面两个都没用直接看最后一个归并排序. 冒泡排序(超时了) public ListNode s ...
- LeetCode 153. Find Minimum in Rotated Sorted Array寻找旋转排序数组中的最小值 (C++)
题目: Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand. ( ...
- Wireshark的简单使用
TCP包 先看一下Wireshark抓到的TCP的包对应的协议层: Frame:对应是物理层,主要是传输bit流. Ethernet:数据链路层,传输数据帧,二层通信主要是通过mac地址. Inter ...
- B1042 字符统计 (20 分)
#include<cstdio> #include<iostream> #include<algorithm> #include<string> usi ...
- [LeetCode] 235. Lowest Common Ancestor of a Binary Search Tree 二叉搜索树的最小共同父节点
Given a binary search tree (BST), find the lowest common ancestor (LCA) of two given nodes in the BS ...
- 区间DP(超详细!!!)
一.问题 给定长为n的序列a[i],每次可以将连续一段回文序列消去,消去后左右两边会接到一起,求最少消几次能消完整个序列,n≤500. f[i][j]表示消去区间[i,j]需要的最少次数. 则; 若a ...