AI智能
改变未来

Django边学边记—模板


功能

  • 产生html,且不仅仅是一个html 包含:静态内容:html,css,js
  • 动态内容:模板语言

使用

  • 一般使用 Django中提供的简写函数render调用模板
  • render(request,\'XXX.html\',{XX,XX})

模板语言(DTL)

  • 变量

  • 语法:{{ 变量 }}
  • 变量名必须由字母、数字、下划线(不能以下划线开头)和点组成
  • 解析顺序:当变量中有点.的时候 解析顺序如下:把点前面的部分当成字典,点后面的当成key
  • 把点前面的当成对象,点后面的当成属性
  • 把点前面的当成对象,点后面的当成对象的方法
  • 如果点后面数字,把点前面当成列表,点后面当成下标
  • 都取不到值,就将变量设为空字符串
  • 标签(tags)

  • 语法:{% 代码段 %}
      for标签{%for item in 列表%}
    • 循环逻辑
    • {{forloop.counter}}表示当前是第几次循环,从1开始
    • {%empty%}
    • 列表为空或不存在时执行此逻辑
    • {%endfor%}
  • if标签
      {%for item in 列表%}
    • 循环逻辑
    • {{forloop.counter}}表示当前是第几次循环,从1开始
    • {%empty%}
    • 列表为空或不存在时执行此逻辑
    • {%endfor%}
  • 比较运算符如下:==、!=、<、>、<=、>=
      注意:运算符左右两侧必须有空格
  • 布尔运算符如下:and、or、not
  • 过滤器(filter)

  • 对常量进行一些操作,可以用过滤器,语法如下:
  • 变量|过滤器:参数
  • 常用的过滤器有:date,default,length等,具体可参考Django文档
  • 内置模板标签和过滤器 | Django 文档 | Djangohttps://docs.djangoproject.com/zh-hans/3.2/ref/templates/builtins/#ref-templates-builtins-filters
  • 自定义模板标签和过滤器

      共需要5步
    1. 在应用中创建templatetags目录。(添加
      templatetags

      模块后,需要重启服务器)

    2. 在上面目录中创建__init__.py 和模块名.py 文件。(要自定义的 tags或filters模块)
    3. 导入模块,创建一个Library对象,用于装饰自定义的过滤器
      from django import templateregister = template.Library()
    4. 编写自定义的函数,并用上面装饰器进行装饰注册。(函数至少接受1个最多接受2个参数)
      @register.filterdef XXX(num,[]):return XXX
    5. 在html模板中加载自定义的过滤器
      {% load 模块名 %}
  • 注释

  • 在模板中使用模板注释,注释的代码不会被编译,不会输出到客户端;与html注释不同的是html注释只能注释html内容,不能注释模板语言,且会输出到客户端。
      单行注释语法: {#…#}
    1. 多行注释使用comment标签,语法:{%comment%}
      ...

      {%endcomment%}

    模板继承

    • 主要是为了提高代码重用,减轻开发人员的工作量
    • 典型应用:网站的头部、尾部信息

    父模板

    • 如果发现在多个模板中复制一段代码,那就应该把这段内容定义到父模板中
    • 标签block:用于在父模板中预留区域,留给子模板填充差异性的内容,名字不能相同
    • 为了更好的可读性,建议给endblock标签写上名字,这个名字与对应的block名字相同
    • 父模板中也可以使用上下文中传递过来的数据
    {%block 名称%}预留区域,可以编写默认内容,也可以没有默认内容{%endblock  名称%}

    子模板

    • 标签extends:继承,写在子模板文件的第一行
    {% extends \"父模板名称.html\"%}
    • 子模版不用填充父模版中的所有预留区域,如果子模版没有填充,则使用父模版定义的默认值
    • 填充父模板中指定名称的预留区域
    {%block 名称%}实际填充内容{{block.super}}用于获取父模板中block的内容{%endblock 名称%}

    HTML转义

    • 出于安全考虑,模板对上下文传递的字符串进行输出时,会对以下字符自动转义

      小于号< 转换为&lt;

      大于号> 转换为&gt;

      单引号\’ 转换为'

      双引号\” 转换为 &quot;

      与符号& 转换为 &amp;

    • 关闭转义主要有2种方法:

      单个变量可以用过滤器safe:{{变量|safe}}

    • 设置一段代码都禁用转义,使用标签autoescape:接受on、off参数

    {%autoescape off%}

    {%endautoescape%}

    CSRF

    • CSRF全拼为Cross Site Request Forgery,译为跨站请求伪造。
    • 重要信息如金额、积分等,采用POST方式传递
    • 启用CSRF中间件,默认启用
    • 在form表单中加入标签{% csrf_token %}
    • 如果不个别视图关闭csrf验证可以用装饰器
    • from django.views.decorators.csrf import csrf_exempt@csrf_exemptdef getip(request):pass

    反向解析

    • 作用:

      从相应的 Django 视图标识以及要传递给它的参数来获取相关联的 URL

    • 当一个url配置的地址发生改变时,页面上使用反向解析生成地址的位置不需要变化
  • 实现步骤

      在 项目/urls.py 中为include定义namespace属性

      url(r\'^\',include(\'app.urls\',namespace=\'app\'))
    • 在app/urls.py中 设置app名字
      app_name = \'app\'
    • 在app/urls.py中为url定义name属性
      url(r\'^test/$\', views.test,name=\'test\')
  • 使用

  • 在模板里:使用url模板标签。{%url \’namespace:name\’ [a[=x] b[=x]] %}
  • 在 Python 编码:使用reverse()函数。reverse(\’namespace:name\’, kwargs={\’a\’:x,\’b\’:y})
      reverse 函数导入

      from django.urls import reverse
  • 赞(0) 打赏
    未经允许不得转载:爱站程序员基地 » Django边学边记—模板