美文网首页
4. 模板标签与模板继承

4. 模板标签与模板继承

作者: 爱修仙的道友 | 来源:发表于2019-02-21 17:03 被阅读0次

1. 模板标签

  • 作用是什么?
    标签在渲染的过程中提供任意的逻辑
class Index(View):
    def get(self, request):

        students = [
            {'name':'张三', 'age':17, 'sex':'男'},
            {'name':'李四', 'age':15, 'sex':'女'},
            {'name':'王五', 'age':19, 'sex':'男'},
            {'name':'赵六', 'age':14, 'sex':'女'},
            {'name':'钱七', 'age':18, 'sex':'男'},
        ]
        return render(request, 'index/home.html', context={
            'students':students,
        })
          <div class="inner cover">
            <h1 class="cover-heading">学生信息表</h1>
            <table class="table">
              <tr>
                <td>序号</td>
                <td>姓名</td>
                <td>年龄</td>
                <td>性别</td>
              </tr>
              {% for student in students %}
                <tr>
                <td>{{ forloop.counter }}</td>
                <td>{{ student.name }}</td>
                <td>{{ student.age }}</td>
                <td>{{ student.sex }}</td>
                </tr>
              {% endfor %}
            </table>
          </div>
简单展示.png
  • 常用标签

    • if/elif/else: 可以使用and/or/in/not/==/!=/<=/>=,来进行判断
                 {% if students.name == "张三" %}
                         我的名字是张三
                 {% elif students.name == "李四" %}
                         我的名字是李四
                 {% else %}
                         我的名字是王五
                 {% endif %}
      
    • for...in...:
      • forloop.counter: 当前迭代的次数,下标从1开始. 1 2 3
      • forloop.counter0: 当前迭代的次数,下标从0开始. 0 1 2
      • forloop.revcounter: 当前迭代的次数,下标从大到小. 3 2 1
      • forloop.revcounter0: 当前迭代的次数,下标从大到小. 2 1 0
      • forloop.first: 返回bool类型,如果是第一次迭代,返回True,否则返回False
      • forloop.last: 返回bool类型,如果是最后一次迭代,返回True,否则返回False
      • forloop.parentloop: 如果发生多层循环嵌套,那么这个变量返回的是上一层的for
               {% for student in students %}
                 <tr>
                 <td><a href="{% url 'index:home' %}">{{ forloop.counter }}</a></td>
                 <td>{{ student.name }}</td>
                 <td>{{ student.age }}</td>
                 <td>{{ student.sex }}</td>
                 </tr>
               {% endfor %}
      
    • for...in...empty...:如果没有数据,跳转到empty中
              {% for student in students %}
                  xxx
              {% empty %}  
                  yyy
              {% endfor %}
      
    • load: 加载第三方标签 {% load static %}
    • url:返回一个命名了的url的绝对路径
      • <a href="{% url 'app_name:name' 参数 %}"> (若有参数,则需空格隔开)
      <a href="{% url 'index:home' stu.id %}">
      
    • with:缓存一个变量,相当于重命名
              {% with students.0.name as stu  %}
                {{ stu }}
              {% endwith %}
      
    • autoescape:开启和关闭自动转义


      image.png
  • 语法

    • {% tag %} {% endtag %}
    • {% tag 参数 参数 %}

2.模板的继承与引用

Django模版引擎中最强大也是最复杂的部分就是模版继承了。 模版继承可以让你创建一个基本的“骨架”模版,它包含您站点中的全部元素,并且可以定义能够被子模版覆盖的 blocks

  • 引用 include标签
  • 继承 extends标签

模板继承使用extends标签实现。通过使用block来给子模板开放接口。
1、extends必须是模板中的第一个出现的标签。
2、子模板中的所有内容,必须出现在父模板定义好的block中,否则django将不会渲染。
3、如果出现重复代码,就应该考虑使用模板。
4、尽可能多的定义block,方便子模板实现更细的需求。
5、如果在某个block中,要使用父模板的内容,使用block.super获取


image.png

相关文章

  • 4. 模板标签与模板继承

    1. 模板标签 作用是什么?标签在渲染的过程中提供任意的逻辑 常用标签if/elif/else: 可以使用and/...

  • Django模板标签

    知识点: 基本概念 常用标签 模板标签例子 模板继承与应用 注释标签 模板文件路径设置 模板标签 标签在渲染的过程...

  • Flask基础03

    模板 1 模板的继承 什么是模板的继承​ 模板的继承类似于类的继承,如果一个模板中所出现的大量内容与另一个模板...

  • 08_模板层补充

    模板层 一、模板层导入与继承 模板导入: 先码一个好看的模板 语法:{% include '模板名称' %} 模板...

  • 静态模版的抽取与引用

    模板继承使用extends标签实现。通过使用block来给子模板开放接口。 1、extends必须是模板中的第一个...

  • django学习3

    创建模板 在templates下创建模板base.htmlblock , mainbody 标签是可以被继承者替换...

  • 05-Django模板

    一、模板概述 模板组成 作用 优点 模板处理 二、定义模板 变量 标签 单行注释 标签if 标签for 标签com...

  • 05-Django模板

    一、模板概述 模板组成 作用 优点 模板处理 二、定义模板 变量 标签 单行注释 标签if 标签for 标签com...

  • 模板标签、模板的引用和模板继承的综合运用(十五)

    题目:实现学生列表的案例,要求用到模板继承,模板引用,和for,forloop,if,url等常用标签。 1、将学...

  • Flask框架从入门到精通之模板导入与继承(十八)

    知识点:1、模板导入2、模板继承 一、概况 模板导入就是将另一个模板加载到当前模板中,直接渲染。模板继承和类的继承...

网友评论

      本文标题:4. 模板标签与模板继承

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