菜单
×
   ❮   
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

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>

您是否在 <title> 元素和 <body> 元素中看到了 Django 的 block 标签?

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


修改模板

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

这通过使用 {% extends %} 标签包含主模板,并插入 title 块和 content 块来完成。

Members

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 manage.py runserver

×

联系销售

如果您想将 W3Schools 服务用于教育机构、团队或企业,请发送电子邮件给我们
sales@w3schools.com

报告错误

如果您想报告错误,或想提出建议,请发送电子邮件给我们
help@w3schools.com

W3Schools 经过优化,旨在方便学习和培训。示例可能经过简化,以提高阅读和学习体验。教程、参考资料和示例会不断审查,以避免错误,但我们无法保证所有内容的完全正确性。使用 W3Schools 即表示您已阅读并接受我们的使用条款Cookie 和隐私政策

版权所有 1999-2024 Refsnes Data。保留所有权利。W3Schools 由 W3.CSS 提供支持