Django_templates 速查fittler
2018-02-09 本文已影响18人
两点半的杂货铺
一、系统自带的过滤
-
语法的格式:
{{obj|filter:param}}
-
upper 小写变成大写
value1="aBcDe"
{{ value1|upper }}
打印结果ABCDE
-
add 变量求和
value2=2
{{ value2|add:3 }}
打印结果5
-
date页面展示的时间格式
import datetime
value4=datetime.datetime.now()
{{ value4|date:'Y-m-d' }}
打印结果2018-2-9
-
cut 去掉字符串中指定元素
value3='he llo wo r ld'
{{ value3|cut:' ' }}
打印结果helloworld
-
default列表不存在时设置默认
value5=[]
{{ value5|default:'空的' }}
打印结果空的
-
autoescape off 和safe 允许展示用户的html代码
value6='<a href="#">跳转</a>'
{% autoescape off %}
{{ value6 }}
{% endautoescape %}
{{ value6|safe }}
-
striptags 去掉标签只展示内容
value6='<a href="#">跳转</a>'
{{ value6|striptags }}
打印结果跳转
-
filesizeformat 展示文件或变量的大小
value7='1234'
{{ value7|filesizeformat }}
打印结果1.3KB
-
first 显示第一个
value7='1234'
{{ value6|first }}
打印结果1
-
length 显示长度
value7='1234''
{{ value6|length }}
打印结果4
-
slice切片
value7='1234'
{{ value6|slice:-1}}
打印结果123
二、自定义fittler
1.在setting.py中注册app
2.在app文件中创建目录templatetags
3.创建python文件
注:只能接收一个参数,但可以列表形式多传入,能作为if条件
from django import template
from django.utils.safestring import mark_safe
register = template.Library()
#其中v1是页面指定的函数
@register.filter
def test(v1,v2):
return v1+v2+v3
例如上面的文件叫myTag在html下引用
引用
{% load myTag %}
使用
{{后台传递参数|函数名:参数 }}
三、自定义simple_tag:
1.在setting.py中注册app
2.在app文件中创建目录templatetags
3.创建python文件
注:只能接收多个参数,不能作为if条件
from django import template
from django.utils.safestring import mark_safe
register = template.Library()
@register.simple_tag
def test(v1,v2,v3):
return v1+v2+v3
例如上面的文件叫myTag在html下引用
引用
{% load myTag %}
使用
{% test 1 2 3 %}
-
前端代码显示
from django.utils.safestring import mark_safe
@register.simple_tag
def safe_html(html):
return mark_safe(html)
四、系统标签使用{% tags %}
-
{{ forloop.counter }}计数,生成序号从1开始
{% for item in todo_list %}
<p>{{ forloop.counter }}: {{ item }}</p>
{% endfor %}
-
{{ forloop.counter0 }}计数,生成序号从0开始
-
{{ forloop.revcounter}}计数,生成序号倒叙
-
{{ forloop.revcounter0 }}计数,生成序号倒叙0收尾
-
{{ forloop.first}}当第一次循环时值为True
{% for object in objects %}
{% if forloop.first %}
<li class="first">
{% else %}
<li>
{% endif %}
{{ object }}
</li>
{% endfor %}
-
{% if %} 条件判断如果
注明:
1.变量和判断之间要有空格例,结尾要用end结束
2.{% if %} 标签接受and,or或者not来测试多个变量值或者否定一个给定的变量
{% if %} 标签不允许同一标签里同时出现and和or,否则逻辑容易产生歧义,例如下面的标签是不合法的:
{% if obj1 and obj2 or obj3 %}
报错
{% if num>=100%}
报错
{% if num >= 100%}
正确
例子
{% if num >= 100 and 8 %}
{% if num > 200 %}
<p>num大于200</p>
{% else %}
<p>num大于100小于200</p>
{% endif %}
{% elif num < 100%}
<p>num小于100</p>
{% else %}
<p>num等于100</p>
{% endif %}
-
{%for%}循环遍历
{% for %}
标签允许你按顺序遍历一个序列中的各个元素,每次循环模板系统都会渲染{% for %}
和{% endfor %}
之间的所有内容
-
{%csrf_token%}
用于生成csrf_token的标签,用于防治跨站攻击验证。注意如果你在view的index里用的是render_to_response方法,不会生效
其实,这里是会生成一个input标签,和其他表单标签一起提交给后台的。
-
{% url '别名' %}
{% url %}: 引用路由配置的url name属性的名字
-
{% with %}起别名
{% with total=fhjsaldfhjsdfhlasdfhljsdal %} {{ total }} {% endwith %}
-
{% verbatim %} 正常显示,不进行转换
{% verbatim %}
{{ hello }}
{% endverbatim %}