一、模板常用语法

1.1 变量

  1. 符号:{{ }}

    • 表示变量,在模板渲染的时候替换成值
    • 使用方式:{{ 变量名 }}:变量名由字母数字和下划线组成
    • 点(.)在模板语言中有特殊的含义,用来获取对象的相应属性值
    • 注意:当模板系统遇到一个(.)时,会按照如下的顺序去查询:
      • 在字典中查询
      • 属性或者方法
      • 数字索引

1.2 内置filter

  1. filter:过滤器,用来修改变量的显示结果

    • 语法: {{ value|filter_name:参数 }}
    • ':'左右没有空格没有空格没有空格
  2. 内置过滤器

    • 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

  1. 在app下创建一个名为templatetags的python包

  2. 在templatetags中创建py文件,文件名自定义(my_tags.py);

  3. 在py文件中写:

    from django import template
    register = template.Library() # register也不能变
  4. 写函数+装饰器

    @register.filter
    def add_xx(value, arg): # 最多有两个
    return '{}-{}'.format(value, arg) @register.filter(name='adds') # 相当于更改了函数名,使用时,使用新的函数名
  5. 在模板文件中使用,html文件

    {% load my_tags %}
    {{ 'alex'|add_xx:'dsb' }}
  6. 注意:

    • 为避免出错,templatetags最好是一个Python包,并且名称不能更改
    • register名称也不能更改,必要时需要重启项目
    • Python包下的init中可能有其他内容django不能识别,导致出错,可以直接删除内容

1.4 标签tag

  1. 符号:{% %}

  2. 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 %}
  3. 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
      • 模板中,不支持连续连续判断 也不支持算数运算(可使用过滤器)
  4. with:给变量重命名,但只在with区域内生效

    {% with hobby.2 as talk %}
    {# 相当于 {% with talk=hobby.2 %},其中=两边不能有空格 #}
    {{ talk }}
    {% endwith %}
  5. csrf_token

    • 该标签用于跨站请求伪造保护

      • csrf:跨站请求伪造
    • 使用方式:在form表单中写上{% csrf_token %}
    • 这样就不用在settings中注释含csrf的中间件了

1.5 注释

  • 符号:{# 要注释的内容 #}

  • 快捷键:Ctrl + ?

    {# 要注释的内容 #}

二、母板和继承

2.1 母板

  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>
  2. block块:

    {% block 块名 %}
    
    {% endblock %}
  3. 注意:我们通常会在母板中定义页面专用的CSS块和JS块,方便子页面替换

2.2 继承

  1. 子页面继承母板:{% extends '母板html' %}

    {% extends 'layouts.html' %}
  2. 子页面通过重写block块,来替换母板中相应的内容

    {% block page-main %}
    <p>世情薄</p>
    <p>人情恶</p>
    <p>雨送黄昏花易落</p>
    {% endblock %}

2.3 注意

  1. {% extends 'base.html' %}要写在第一行,前面不要有内容,否则内容会显示出来
  2. {% extends 'base.html' %}中的'base.html' 必须加上引号,不然会被当做变量去查找
  3. 子页面把要显示的内容写在block块中,否则不会显示出来
  4. 多个位置有独特内容,可以定义多个block块,特殊:定义css、js块等

三、组件

  1. 组件:一小段html代码段

  2. 可以将常用的页面内容如导航条,页尾信息等组件保存在单独的文件中,然后在需要使用的地方导入

    {% include 'navbar.html' %}

四、静态文件相关

  1. 目的:更改setting中静态文件的别名时,不影响在更改之前的静态文件的引用,即引用会跟随别名的更改而自动更改,这样就不会报错了

  2. 方法一:使用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 }}">
  3. 方法二:使用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

  1. 和自定义filter类似,区别:接收的参数更灵活,能接收万能参数

  2. 定义注册simple_tag

    @register.simple_tag
    def join_str(*args, **kwargs):
    return '{} - {} '.format('*'.join(args), '$'.join(kwargs.values())) @register.simple_tag(name='join') # 相当于更改了函数名,使用时,使用新的函数名
  3. 使用自定义simple_tag

    {% load my_tags %}
    {% join_str '1' '2' k1='3' k2='4' %}

六、inclusion_tag

  1. 在app下的templatetags(python包)中创建py文件,文件名自定义(my_inclusion.py);

  2. 在py文件中写:

    from django import template
    register = template.Library() # register也不能变
  3. 写函数+装饰器

    @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}
  4. 在result.html中写:

    <ul>
    {% for choice in data %}
    <li>{{ choice }}</li>
    {% endfor %}
    </ul>
  5. 在模板文件中使用

    {% load my_inclusion %}
    {% show_results 10 %}

Django模板系统:Template的更多相关文章

  1. Django 模板系统(template)

    介绍 官方文档 常用模板语法 只需要记两种特殊符号: {{  }} 和  {% %} 变量相关的用{{}} 逻辑相关的用{%%} 变量 {{ 变量名 }} 变量名由字母数字和下划线组成. 点(.)在模 ...

  2. Django模板(Template)系统

    Django模板系统 官方文档 常用语法 只需要记两种特殊符号: {{  }}和 {% %} 变量相关的用{{}},逻辑相关的用{%%}. 变量 {{ 变量名 }} 变量名由字母数字和下划线组成. 点 ...

  3. django模板系统基础

    模板系统基础Django模板是一个string文本,它用来分离一个文档的展现和数据 模板定义了placeholder和表示多种逻辑的tags来规定文档如何展现 通常模板用来输出HTML,但是Djang ...

  4. Django——模板层(template)(模板语法、自定义模板过滤器及标签、模板继承)

    前言:当我们想在页面上给客户端返回一个当前时间,一些初学者可能会很自然的想到用占位符,字符串拼接来达到我们想要的效果,但是这样做会有一个问题,HTML被直接硬编码在 Python代码之中. 1 2 3 ...

  5. python MVC、MTV 框架介绍 Django 模板系统常用语法

    Django 框架简介一.MVC框架和MTV框架1.MVC 全名Model View Controller,是软件工程中的一种软件架构模式,把软件系统分为三个基本部分.优势: 耦合性低 重用性高 生命 ...

  6. Django 模板系统

    Django模板系统 常用语法 {{}} 变量相关 {%%} 逻辑相关 变量 格式 {{ 变量名 }} 命名规则 包括任何字母数字以及下划线 ("_")的组合 变量名称中不能有空格 ...

  7. Python学习(二十八)—— Django模板系统

    转载自http://www.cnblogs.com/liwenzhou/p/7931828.html Django模板系统 官方文档 一.常用语法 只需要记两种特殊符号: {{  }}和 {% %} ...

  8. Django模板系统(非常详细)(后台数据如何展示在前台)

    前面的章节我们看到如何在视图中返回HTML,但是HTML是硬编码在Python代码中的这会导致几个问题:1,显然,任何页面的改动会牵扯到Python代码的改动网站的设计改动会比Python代码改动更频 ...

  9. (转)Django学习之 第四章:Django模板系统

    前面的章节我们看到如何在视图中返回HTML,但是HTML是硬编码在Python代码中的 这会导致几个问题: 1.显然,任何页面的改动会牵扯到Python代码的改动 网站的设计改动会比Python代码改 ...

随机推荐

  1. mysql的创建数据库表及添加数据

    C:\Users\ceshi>mysql -u root -pEnter password: ******Welcome to the MySQL monitor. Commands end w ...

  2. eth0: ERROR while getting interface flags: No such device的解决方法、Linux怎么修改IP以及ping不通的处理方法

    首先输入ifconfig命令查看当前的ip信息 发现没有eth0这个网卡设备,有ens33 接着输入命令:ifconfig ens33 192.168.2.110    --  修改临时ip地址,系统 ...

  3. loadrunner12 Runtime Settings位置

  4. 每天一道Rust-LeetCode(2019-06-14)

    每天一道Rust-LeetCode(2019-06-14) 常数时间插入.删除和获取随机元素 坚持每天一道题,刷题学习Rust. 题目描述 https://leetcode-cn.com/proble ...

  5. Session技术

    Session 学习: 问题: Request 对象解决了一次请求内的不同 Servlet 的数据共享问 题,那么一个用户的不同请求的处理需要使用相同的数据怎么办呢? 解决: 使用 session 技 ...

  6. AWS云教育账号创建以及搭建数据库

    注册过程繁琐,本文强调关键几点 首先拿到aws的二维码,进入之后填写相关个人信息,用学校邮箱注册,用学校邮箱注册!! 之后审核会有大约10分钟的过程,之后会收到确认邮件 点进去之后就可以设置自己的密码 ...

  7. Mysql对表中 数据 的操作 DML

    上一知识点回顾: mysql的备份: 直接使用navicat进行备份 转储SQL文件:有结构和数据/ 仅结构 两种 需要还原时 单击 数据库名字  运行SQL文件  创建表ctreate 修改表alt ...

  8. Laravel 推荐-基础入门+实战+拓展视频教程

    1.laravel基础 1.Composer:类库管理神器 - Laravel的安装和配置 2.路由:地址和方法的小媒人 - 基础路由 3.控制器:管家婆 - 基础用法 4.视图:最终结果输出 5.b ...

  9. n8n 基于node 的流程自动化工具

    n8n 是基于node开发的流程自动化工具,提供了可视化的操作,我们可以用来集成不同的服务. 目前已经提供了很多的服务集成组件,同时我们也可以方便的自己扩展,后边会进行一个系统的 学习,同时介绍下使用 ...

  10. TCP三次握手及四次断开,TCP有限状态机

    TCP 的连接建立 上图画出了 TCP 建立连接的过程.假定主机 A 是 TCP 客户端,B是服务端.最初两端的 TCP 进程都处于 CLOSED 状态.图中在主机下面的是 TCP进程所处的状态.A ...