美文网首页
Django_templates 速查fittler

Django_templates 速查fittler

作者: 两点半的杂货铺 | 来源:发表于2018-02-09 16:16 被阅读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 %}

相关文章

网友评论

      本文标题:Django_templates 速查fittler

      本文链接:https://www.haomeiwen.com/subject/wmuftftx.html