**Django模板语言**

Django模板语言
一.与变量相关的
1.在Django中使用符号:{{变量}} 来对变量进行操作。当在一个html页面中出行该符号是,将会相应的变量来替换该位置。
2.命名规则:与在python中的命名规则一致,可以为字母,下划线,数字的组合。
3.相应操作:
1.“ . ”:具有查询作用。可以使用其获取字典,列表,对象中的元素或属性,方法等。若查询到结果可被调用,则会无参调用,无法传入自定义参数,并将调用的结果来替换该变量,若无查询到该变量,将会默认为空字符串。
查询顺序为:
字典中的值 > 属性 > 方法 > 数字索引(list.0 将会获取到对应列表的第一个元素)
2. 过滤器 : 可以通过过滤器来对变量进行设置。
格式为:{{ 变量 | 过滤器名 : 相应参数 }} 参数可以没有, 可以支持链式操作,如:{{name|slice:’0:2’|lower}}。注意:”|”左右没有空格,若参数中含有空格,需用’’包起来。

3.常用的内置过滤器:
1.upper,lower:upper是将小写字母转化成大写,lower与之相反。

2.lenght:相当于python中的len函数,是获取到变量的长度。

3.filezeformat:将文件大小(单位为byte)转换成便于人们读取的格式,如KB,MB…….将会自动转换成合适的单位,最小单位为byte。该变量可以为数字,字符串表示的数字,将会将自动取整,若变量为不是以上两种,将会返回0 bytes。

4.Slice:将变量进行切片,将要传入参数为切片的范围,需使用引号包起来。若变量不支持切片操作,将会返回变量本身。

5.truncatechars: 有一个参数,为数字,将会根据参数以字符为单位获取到相应长度的字符串(注意:由 … 结尾,且将会占用一个字符的位置)。

6.truncatewords:有一个参数,为数字,将会根据参数获取到相应数量的单词,(单词:是由空格为界线),由 … 结尾,不占用单词的位置。若变量不为字符串,则会将变量转换成字符串。

7.safe:将会关闭django中对HTML语句的自动转义。

8.Cut:有一个参数,为将把变量中要移除字符串。将会根据参数,把变量中的参数移除,返回移除后的字符串。

9.Join:有一个参数。将会根据参数将一个可迭代对象使用参数连接起来生成一个字符串,当变量为字典时,将会使用字典的键进行拼接。

4.自定义filter
需要创建一个包名称必须为:templatetags,在这个包中创建py文件,编写函数。需要在该py文件中导入django中的template, 并生成register = template.Library(),并使用register.filter()来装饰自定义的函数。作用是告诉django的模板语言,有自定义的filter。当使用时,需导入自定义函数所在的py文件。格式为:{% load 文件名 %}。

二.与逻辑相关的
1.在django中使用{% 逻辑语句 %}在html页面中来实现一些简单的逻辑语句。
2.逻辑语句
1.for循环:格式为
{% for i in list %}
操作语句
{% endfor%}
其中有一些可用的参数,可使用forloop进行调用。Forloop为一个字典
Key Value
counter 当前循环的索引值,(从1开始)
counter0 当前循环的索引值,(从0开始)
revcounter 当前循环的索引值的倒序,(从1开始)
revcounter0 当前循环的索引值的倒序,(从0开始)
first 当前循环是否为第一次循环,(为布尔值)
last 当前循环是否为最后一次循环,(为布尔值)
parent loop 为该循环的外层循环的forloop

for…empty: 格式为:
{% for i in list %}
操作语句1
{% empty %}
操作语句2
{% endfor%}
当循环为空时将会执行操作语句2。
2.if判断:格式为:
{% if 判断语句 %}
操作语句
{%elif%}
操作语句
{% else%}
操作语句
{% endif %}
注意:判断中不支持连续判断,如 10>5>1结果为假。
3.with 语句:是对一个复杂的变量起别名,格式为:{% with 变量 as 别名%}或{% with 变量=别名%} 注意:等号两边没有空格。

4.csrf_token: 该标签用跨站请求伪造保护,将该标签写在form表单里。格式为:{% csrf_token %}

5.母板:当某几个页面中仅有某几部分不同,其他的代码都相同时。可以使用母板来减少代码量。与继承相类似。
block块:在母板文件中定义block块,格式为:{% block 名称 %}
代码块
{% endblock%}
使用步骤:
先创建好母板文件,在模板文件中的相应位置定义block块
创建一个子文件,继承母板文件:{% extends ‘母板文件名 ’ %}
定义block块,在block块中放入代码块,当时有该子文件时,将会 返回由子文件中代母块替换母板文件中的代码块后的页面
注意:继承母板时,母板名称需要加上引号,若未加引号,将会被当成变 量取寻找。无法找到相应的母板文件。

6.组件:当页面中使用到一些常用的且可单独分离出来的代码时,可以将相应的代码块单独放在一个文件中,使用时对其进行导入。
格式:{% include 文件名 %}

7.simple_tag:对于自定义的filter只能传入一个自定义的参数。具有很大的局限性。定义simple_tag可以解决这个问题。
将函数定义在templatetas中,并生成register = template.Library()
使用register.simple_tag()进行装饰。
使用格式:{% 函数名 参数1 参数2……%} 参数与参数之间使用空格隔开。

8.Inclusion_tag:可以返回一个HTML某一个代码块,和include有相似的功能,但其可以在使用到django的模板语言。比include更加方便。
使用步骤:
在创建的app文件下的templatetags包中创建一个py文件。
在该py文件下导入django中的template, 并生成register = template.Library()
并使用register.inclusion_tag(需要参入存放代码块的文件名)来装饰函数。
在使用改代码块的文件中,可使用{% 函数名 参数1 参数2……%} 参数与参数之间使用空格隔开,使用该代码块。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值