• Django-模板继承、包含和静态文件配置


    一、模板继承

    • 模板继承可以减少页面内容的重复定义,实现页面内容的重用
    • 典型应用:网站的头部、尾部是一样的,这些内容可以定义在父模板中,子模板不需要重复定义
    • block标签:在父模板中预留区域,在子模板中填充
    • extends继承:继承,写在模板文件的第一行
    • 定义父模板base.html

    步骤:

      1.  把公共的HTML部分提取到一个base.html中,构建一个基本的HTML“骨架”

      2.  在母板中,通过定义block块,告诉模块引擎子模块可以覆盖母板的哪些部分。

      3. 在子模板的首行使用{% extend 'base.html' %}指定继承自哪个母板

      4. 在子模板中使用和母板中相同的block,来覆盖母板中指定的位置

    代码:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <link rel="stylesheet" href="style.css" />
        <title>{% block title %}My amazing site{% endblock %}</title>
    </head>
    
    <body>
        <div id="sidebar">
            {% block sidebar %}
            <ul>
                <li><a href="/">Home</a></li>
                <li><a href="/blog/">Blog</a></li>
            </ul>
            {% endblock %}
        </div>
    
        <div id="content">
            {% block content %}{% endblock %}
        </div>
    </body>
    </html>
    母板
    {% extends "base.html" %}
    
    {% block title %}My amazing blog{% endblock %}
    
    {% block content %}
    {% for entry in blog_entries %}
        <h2>{{ entry.title }}</h2>
        <p>{{ entry.body }}</p>
    {% endfor %}
    {% endblock %}
    子模板

    二、包含

    include:在模板中“包含”其他模板的一种方式。模板名称可以是变量,也可以是单引号或双引号的硬编码(带引号)的字符串。

    此示例包含模板的内容"foo/bar.html"

    {% include "foo/bar.html" %}

    通常,模板名称是相对于模板加载程序的根目录。一个字符串参数也可以是一个 以标签开始./或者../extends标签所描述的相对路径

    此示例包含名称包含在变量中的模板的内容template_name

    {% include template_name %}

    三、静态文件配置

    • 项目中的CSS、图片、js都是静态文件
    • 配置静态文件

      • 在settings 文件中定义静态内容
    STATIC_URL = '/static/'
    STATICFILES_DIRS = [
        os.path.join(BASE_DIR, 'static'),
    ]
    • 在项目根目录下创建static目录,再创建当前应用名称的目录
    mysite/static/myapp/
    • 在模板中可以使用硬编码
    /static/my_app/myexample.jpg
    • 在模板中可以使用static编码
    { % load static from staticfiles %}
    <img src="{ % static "my_app/myexample.jpg" %}" alt="My image"/>
  • 相关阅读:
    卿学姐与魔法(优先队列)
    H国的身份证号码(搜索)
    钓鱼(贪心,优先队列)
    Communication System(动态规划)
    最长连续01字符串
    魔法跳舞链 (最小生成树)
    括号匹配(线段树)
    bzoj 1042: [HAOI2008]硬币购物
    bzoj 1057: [ZJOI2007]棋盘制作
    bzoj 1452: [JSOI2009]Count
  • 原文地址:https://www.cnblogs.com/weihengblog/p/9010517.html
Copyright © 2020-2023  润新知