Django_模板继承

文章介绍了Django中的模板继承概念,通过创建一个父模板base.html,包含页面共用元素并定义可被子模板覆盖的blocks。子模板demo.html继承base.html并重写了特定的block内容。进一步地,demo.html还可以被demo1.html继承并继续重写内容,展示了模板继承的层次结构。

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

extends 模板继承

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

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

<!DOCTYPE html>
<html lang="en">
<head>
    <title>{% block title %}基础模板{% endblock %}</title>
</head>

<body>
    <div id="app">
        <!-- 如果是所有页面共用部分,可直接在block外部写死 -->
        <div> 所有页面公用部分 </div>
        <!-- 如果是部分页面共用部分,可定义在block中,不需要使用的页面可重写该block,其中block_name1为block的名称 -->
        {% block block_name1 %}
            <div> 部分页面公用部分1 </div>
        {% endblock %}
        {% block block_name2 %}
            <div> 部分页面公用部分2 </div>
        {% endblock %}
        <!-- 定义的block可以为空白块 -->
        {% block block_name3 %}
        {% endblock %}
    </div>
</body>
</html>

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

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

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

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

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

重写block 

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

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

<!-- 重写tile的block -->
{% block title%} Demo {% endblock %}

<!-- 重写block_name1的block---重写内容 -->
{% block block_name1 %} 重写部分页面公用部分1 {% endblock %}

<!-- 重写block_name2的block---隐藏内容 -->
{% block block_name2 %}{% endblock %}

<!-- 重写block_name3的block---重写内容 -->
{% block block_name3 %}
    <div> hello python!</div>
    <div> 你好,python! </div>
{% endblock %}

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

子模板也可被继承重写

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

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

<!-- 重写tile的block -->
{% block title%} Demo {% endblock %}

<!-- 重写block_name1的block---重写内容 -->
{% block block_name1 %} 重写部分页面公用部分1 {% endblock %}

<!-- 重写block_name2的block---隐藏内容 -->
{% block block_name2 %}{% endblock %}

<!-- 重写block_name3的block---重写内容 -->
{% block block_name3 %}
    <div> hello python!</div>
    <div> 你好,python! </div>
    {% block block_name4 %}
    {% endblock %}
{% endblock %}

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

<!-- 继承demo.html模板 -->
{% extends "demo.html" %}

{% block title%} Demo1 {% endblock %}

{% block block_name4 %}
<div>继承子模板</div>
{% endblock %}

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


源码等资料获取方法

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

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

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值