Django框架(五:模板继承)

模板继承:对于一个网址来说,会存在很对的.html文件,但是由于一些页面中会有相同的页面结构出现,也就导致了.html文件中代码是重复的,所以为了在html中减少重复代码出现,简化html结构,可以将多个页面中相同的html代码,单独的抽离出来放在一个html文件中,其他的html文件如果想要使用这部分内容,直接继承过去就可以了。有的类似于类的继承

首先在urls.py文件中创建多个路由

在这里插入图片描述
对应的views.py

在这里插入图片描述

创建templates目录,建立多个.html文件
在这里插入图片描述
清空上述图片中的前三个.html文件的内容,并将nav.html文件作为父模板,创建内容

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <link rel="stylesheet" href="/static/css/index.css">
        {% block title %}
            <title>导航条</title>
        {% endblock %}

    </head>
    <body>
    <h1>公共的导航条</h1>
    <span>HTML</span>
    <span>CSS</span>
    <span>JS</span>
    </body>
</html>

接下来就是让其它模板引用父模块的内容,怎么引用呢,在第一行添加如下代码即可:

{% extends 'nav.html' %}

其中,extends:关键字编码了当前文件(如:index.html)所继承的父模板

那么问题来了,假如我们想要在继承了父模块的当前文件添加页面内容,又该怎么做呢,
解决方案:
父模块中:使用Django模板标签block(代码块),需要给这个快取个名称 ,在父文件中预留接口,代码:

    {% block title %}
			 <title>导航条</title>
    {% endblock %}
在block块中添加的标签,就相当于是一个title的默认值,如果子模板没有重写这个title快,就是用这个默认值;如果子模板重写了这个title块,就是用子模板重写的值
	子模块中,与父模块保持一致,可以根据需求改变和添加代码:
{% block title %}
    <title>首页</title>
{% endblock %}

最后,static的配置:
它的名称不能改变,创建的位置在根目录下,与app同阶。
在这里插入图片描述
图例:
在这里插入图片描述

对settings.py进行设置:

STATIC_URL = '/static/'

# 搜索根目录下的static
STATICFILES_DIRS = [os.path.join(BASE_DIR,'static')]

运行结果:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值