当前位置:   article > 正文

Django入门(十):模板继承(重要)_django模板继承block标签

django模板继承block标签

1. 介绍

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

模板可以用继承的方式来实现复用,减少冗余内容。

网页的头部和尾部内容一般都是一致的,我们就可以通过模板继承来实现复用。

父模板用于放置可重复利用的内容,子模板继承父模板的内容,并放置自己的内容。

模板继承的应用场景

通常一个网站的某几个页面都有一些公共的布局,如导航栏、侧边栏和页脚的一些地方,如果将这些公共的部分抽离出来,放在一个单独的 html 页面中用于给其他页面继承,就称它为父版,而继承父版的页面就称为子版,同一个父版可以被多个子版继承。

子版中可以继承父版的内容和属性,这样可以使得页面更加简洁,而且在子版中可以修改母版中的部分内容。

2. 父模板 

标签 block...endblock: 父模板中的预留区域,该区域留给子模板填充差异性的内容,不同预留区域名字不能相同。

  1. {% block 名称 %}
  2. 预留给子模板的区域,可以设置默认内容
  3. {% endblock 名称 %}

 3. 子模板

子模板使用标签 extends 继承父模板:

{% extends "父模板路径"%} 

 在子模板中设置父模板预留区域的内容:

  1. { % block 名称 % }
  2. 内容
  3. {% endblock 名称 %}

 子模板如果没有设置父模板预留区域的内容即bolck..endblock区域,则使用在父模板设置的默认内容,当然也可以都不设置,就为空。

4. 简单示例

4.1. 我们在先创建之前项目的 templates 目录中添加 base.html 文件

2.在base.html中输入如下代码:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>DOTmanager教程</title>
  6. </head>
  7. <body>
  8. <h1>hello world!</h1>
  9. <p>Django 测试</p>
  10. {%block body%}
  11. <p>original</p>
  12. {%endblock%}
  13. </body>
  14. </html>

以上代码中,名为 body 的 block 标签是可以被继承者们替换掉的部分。

所有的 {% block %} 标签告诉模板引擎,子模板可以重载这些部分。

3. 在views.py中定义一个新定义一个视图函数

  1. def mydefB(request):
  2. return render(request,"base.html")

 4. 然后在urls.py中配置路由:其中path('base/', views.mydefB),就是我们新增加的路由

  1. urlpatterns = [
  2. path('mytemp/', views.mydef),
  3. path('base/', views.mydefB),
  4. ]

5.  然后我们首先看一下base.html网页显示结果吧:显示成功

6 接下来我们来尝试继承.,   我们在之前一直使用的mytemp.html 中继承 base.html,并替换特定 block,mytemp.html 修改后的代码如下:

 我们仍然在原来代码里面进行新增:

     新增了:{%extends "base.html" %} 这个必须放在标签里面的第一位,否则会报错,大家可以自己尝试,代码意思是:首先载入名为 ‘base’ 的模板中的内容到当前模板

    新增了如下代码:

{% block body %}
<p>not original</p>
{% endblock %}

也就是修改其中名为body的block里面的内容

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. <link rel="stylesheet" href="/static/plugins/bootstrap-3.4.1/dist/css/bootstrap.css">
  7. </head>
  8. <body>
  9. {%extends "base.html" %}
  10. {%load my_tags%}
  11. {% load static %}
  12. <h1>if/else演示</h1>
  13. <ul>
  14. {% block body %}
  15. <p>not original</p>
  16. {% endblock %}
  17. {{num|sub:3}}
  18. {%add 11 12 13%}
  19. {% my_html "zzz" "xxx" %}
  20. {{num}}<img decoding="async" src="{% static 'images/python.png' %}" alt="python-logo">
  21. </ul>
  22. </body>
  23. </html>

7. 结果如下: 可见继承了父模板的内容,但也修改了父模板中body block的内容

8. 细节的同学肯定发现了,为什么执行了extends继承后,mytemp.html里面的其他程序好像没有执行??这个我们继续往下学,我会给大家解答。

5. 总结

  • 如果在模版中使用extends标签,它必须是模版中的第一个标签
  • 不能在一个模版中定义多个相同名字的block标签
  • 子模版不必定义全部父模版中的blocks,如果子模版没有定义block,则使用了父模版中的默认值
  • 如果发现在模板中大量的复制内容,那就应该把内容移动到父模板中
  • 使用可以获取父模板中block的内容
  • 为了更好的可读性,可以给endblock标签一个名字

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Li_阴宅/article/detail/769245
推荐阅读
相关标签
  

闽ICP备14008679号