珍佰农 商城网站建设,自己做的网站出现500错误怎么解决,网络营销员岗位的职责与要求,大连建设工程信息网登陆一个网站中#xff0c;大部分网页的模块是重复的#xff0c;比如顶部的导航栏#xff0c;底部的备案信息。如果在每个页面中都重复的去写这些代码#xff0c;会让项目变得臃肿#xff0c;提高后期的维护成本。比较好的做法是#xff0c;通过模板继承#xff0c;把一些重…一个网站中大部分网页的模块是重复的比如顶部的导航栏底部的备案信息。如果在每个页面中都重复的去写这些代码会让项目变得臃肿提高后期的维护成本。比较好的做法是通过模板继承把一些重复性的代码写在父模板中子模板继承父模板后再分别实现自己页面的代码。我们首先来看一个父模板 base.html 的例子
!DOCTYPE html
html langen
headlink relstylesheet hrefbase.css /title {% block title %} {% endblock %} /title{% block head %} {% endblock %}
/head
bodydiv idbody{% block body %} {% endbody %} /divdiv idfooter{% block footer %}copy; Copyright 2008 by a hrefhttp://domins.invaild/you/a{% endblock %}/div
/body
/html以上父模板中编写好了网页的整体结构并且把所有子模板都需要用到的样式文件 base.css 也提前引用好了。然后针对子模板需要重写的地方则定义成了 block比如以上定义了 title、head、body、footer 这几个 block子模板在继承了父模板后重写对应 block 的代码即可完成子模板的渲染。这里我们用继承 base.html 的方式实现一个 index.html 文件代码如下
{% extends base.index %}
{% block title %} 首页 {% endblock %}
{% block head %}style typetext/css.detail{color: red;}/style
{% endblock %}
{% block content%}h1这里是首页 /h1p classdetail首页的内容/p
{% endblock %}首先我们通过 extends 语法加载父模板因为 base.html 和 index.html 是在同一级目录下所以直接写“base.html”。这里需要注意的是extends 必须出现在子模版所有代码的最前面。接下来分别实现了 title、head、content 这三个 block实现的 block 中的代码将会被自动填充到父模板指定的位置并且最终会生成一个完成 html 结构的 index.html 文件。
模板中不能出现重名的 block如果一个地方需要用到另外一个 block 中的内容可以使用 self.blockname 的方式进行引用比如
title{% block title %}这是标题{% endblock %}
/title
h1 {{ self.title()}} /h1以上示例代码中h1 标签中通过 {{self.title}} 把 title 这个 block 中的内容引用到 h1 标签中。
如果子模版想要继承父模板中某个 block 的内容比如以上案例中我们想要继承父模板 footer 这个 block 中已有的内容则可以通过 super() 来实现
{% block footer %}{{super()}}// 子模版自己的代码
{% endblock %}如果没有 {{super()}}那么子模版将不能继承父模板 footer 这个 block 中的内容。