当前位置:   article > 正文

Django_模板继承_django模板页的继承

django模板页的继承

模板继承先创建一个父模版,它包含大部页面共有元素,并且需要定义能够被子模板覆盖的blocks标签。

extends 模板继承

通过下面的例子,理解模板继承的概念。

创建base.html文件,写入下面代码:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <title>{% block title %}基础模板{% endblock %}</title>
  5. </head>
  6. <body>
  7. <div id="app">
  8. <!-- 如果是所有页面共用部分,可直接在block外部写死 -->
  9. <div> 所有页面公用部分 </div>
  10. <!-- 如果是部分页面共用部分,可定义在block中,不需要使用的页面可重写该block,其中block_name1为block的名称 -->
  11. {% block block_name1 %}
  12. <div> 部分页面公用部分1 </div>
  13. {% endblock %}
  14. {% block block_name2 %}
  15. <div> 部分页面公用部分2 </div>
  16. {% endblock %}
  17. <!-- 定义的block可以为空白块 -->
  18. {% block block_name3 %}
  19. {% endblock %}
  20. </div>
  21. </body>
  22. </html>

在子模板中直接继承bse.html模板。

创建demo.html文件,写入下面代码:

  1. <!-- 继承base.html模板 -->
  2. {% extends "base.html" %}

写个视图函数调用上面的demo.html模板,然后访问该页面

可以看到子模板显示了父模板所有内容。

重写block 

修改demo.html文件内容如下:

  1. <!-- 继承base.html模板 -->
  2. {% extends "base.html" %}
  3. <!-- 重写tile的block -->
  4. {% block title%} Demo {% endblock %}
  5. <!-- 重写block_name1的block---重写内容 -->
  6. {% block block_name1 %} 重写部分页面公用部分1 {% endblock %}
  7. <!-- 重写block_name2的block---隐藏内容 -->
  8. {% block block_name2 %}{% endblock %}
  9. <!-- 重写block_name3的block---重写内容 -->
  10. {% block block_name3 %}
  11. <div> hello python!</div>
  12. <div> 你好,python! </div>
  13. {% endblock %}

访问demo.html模板,显示的内容如下:

子模板也可被继承重写

修改demo.html文件内容如下:

  1. <!-- 继承base.html模板 -->
  2. {% extends "base.html" %}
  3. <!-- 重写tile的block -->
  4. {% block title%} Demo {% endblock %}
  5. <!-- 重写block_name1的block---重写内容 -->
  6. {% block block_name1 %} 重写部分页面公用部分1 {% endblock %}
  7. <!-- 重写block_name2的block---隐藏内容 -->
  8. {% block block_name2 %}{% endblock %}
  9. <!-- 重写block_name3的block---重写内容 -->
  10. {% block block_name3 %}
  11. <div> hello python!</div>
  12. <div> 你好,python! </div>
  13. {% block block_name4 %}
  14. {% endblock %}
  15. {% endblock %}

新增demo1.html文件内容如下:

  1. <!-- 继承demo.html模板 -->
  2. {% extends "demo.html" %}
  3. {% block title%} Demo1 {% endblock %}
  4. {% block block_name4 %}
  5. <div>继承子模板</div>
  6. {% endblock %}

访问demo1.html,显示的内容如下:


源码等资料获取方法

 各位想获取源码的朋友请点赞 + 评论 + 收藏,三连!

三连之后我会在评论区挨个私信发给你们~

 

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

闽ICP备14008679号