最适合网络开发者的网站
Django。初学者课程

尿素 西斯

Django 添加主模板


extends 标签

在前面的页面中,我们创建了两个模板,一个用于列出所有成员,一个用于列出成员的详细信息。

这两个模板都有一组相同的 HTML 代码。

Django 提供了一种制作“父模板”的方法,您可以将其包含在所有页面中,以执行所有页面中相同的操作。

首先创建一个名为 master.html,包含所有必要的 HTML 元素:

掌握

my_tennis_club/members/templates/master.html:

<!DOCTYPE html>
<html>
<head>
  <title>{% block title %}{% endblock %}</title>
</head>
<body>

{% block content %}
{% endblock %}

</body>
</html>

你看到 Django block Tag 里面 <title> 元素,以及<body> 元素?

它们是占位符,告诉 Django 用来自其他来源的内容替换这个块。


修改模板

现在两个模板(all_members.htmldetails.html)可以使用这个 master.html 模板。

这是通过将主模板与 {% extends %} 标签,并插入title 块和一个content 堵塞:

成员

my_tennis_club/members/templates/all_members.html:

{% extends "master.html" %}

{% block title %}
  My Tennis Club - List of all members
{% endblock %}


{% block content %}
  <h1>Members</h1>

  <ul>
    {% for x in mymembers %}
      <li><a href="details/{{ x.id }}">{{ x.firstname }} {{ x.lastname }}</a></li>
    {% endfor %}
  </ul>
{% endblock %}
运行示例 »

细节

my_tennis_club/members/templates/details.html:

{% extends "master.html" %}

{% block title %}
  Details about {{ mymember.firstname }} {{ mymember.lastname }}
{% endblock %}

{% block content %}
  <h1>{{ mymember.firstname }} {{ mymember.lastname }}</h1>

  <p>Phone {{ mymember.phone }}</p>
  <p>Member since: {{ mymember.joined_date }}</p>

  <p>Back to <a href="/members">Members</a></p>

{% endblock %}
运行示例 »

如果你在自己的计算机上执行了所有步骤,则可以在自己的浏览器中看到结果: 127.0.0.1:8000/members/.

如果服务器宕机,则必须使用 runserver 命令:

py 管理.py 运行服务器


评论