zoukankan      html  css  js  c++  java
  • Flask 学习系列(四)---Jinjia2 模板继承

    1.基模板

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>基模板</title>
        <style type="text/css">
            /* DIVCSS5-CSS初始化模板-www.divcss5.com */
            body, div, ul, li {
                margin: 0;
                padding: 0;
                font-style: normal;
                font: 12px/22px "5B8B4F53", Arial, Helvetica, sans-serif
            }
    
            /* 5B8B4F53 代表 宋体,更多中文字体转 Unicode http://www.divcss5.com/jiqiao/j325.shtml */
            ol, ul, li {
                list-style: none
            }
    
            img {
                border: 0;
                vertical-align: middle
            }
    
            body {
                color: #000000;
                background: #FFF;
                text-align: center
            }
    
            .clear {
                clear: both;
                height: 1px;
                width: 100%;
                overflow: hidden;
                margin-top: -1px
            }
    
            a {
                color: #000000;
                text-decoration: none
            }
    
            a:hover {
                color: #BA2636
            }
    
            .red, .red a {
                color: #F00
            }
    
            .lan, .lan a {
                color: #1E51A2
            }
    
            .pd5 {
                padding-top: 5px
            }
    
            .dis {
                display: block
            }
    
            .undis {
                display: none
            }
    
            ul#nav {
                width: 100%;
                height: 60px;
                background: #00A2CA;
                margin: 0 auto
            }
    
            ul#nav li {
                display: inline;
                height: 60px
            }
    
            ul#nav li a {
                display: inline-block;
                padding: 0 20px;
                height: 60px;
                line-height: 60px;
                color: #FFF;
                font-family: "5FAE8F6F96C59ED1";
                font-size: 16px
            }
    
            ul#nav li a:hover {
                background: #0095BB
            }
    
    
        </style>
    </head>
    <body>
    <ul id="nav">
    <li><a href="http://www.divcss5.com/">首页</a></li>
    <li><a href="http://www.divcss5.com/html/">HTML教程</a></li>
    <li><a href="http://www.divcss5.com/rumen/">CSS基础</a></li>
    <li><a href="http://www.divcss5.com/css-tool/">CSS开发工具</a></li>
    <li><a href="http://www.divcss5.com/css-texiao/">CSS特效</a></li>
    <li><a href="http://www.divcss5.com/wenji/">CSS问题</a></li>
    </ul>
    <div>
        {% block conent %}{% endblock %}
    
    </div>
    </body>
    </html>

    block 是子模板关键字,content在子模板块名称。

    不能砸同一个模板中定义多个同名的block标签。

    子模板

    {% extends "base.html" %}
    {% block conent %}
        <p class="import">
            我是在子模板中
        </p>
    {% endblock %}

    extends  继承父模板的关键字,该标签必须是子模板中的第一个标签。

    渲染子模板的python代码:

    @app.route("/sub")
    def subhtml():
    return render_template("sub.html",site_name="繼承測試")

     运行截图:

    渲染后子页面的html:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>基模板</title>
        <style type="text/css">
            /* DIVCSS5-CSS初始化模板-www.divcss5.com */
            body, div, ul, li {
                margin: 0;
                padding: 0;
                font-style: normal;
                font: 12px/22px "5B8B4F53", Arial, Helvetica, sans-serif
            }
    
            /* 5B8B4F53 代表 宋体,更多中文字体转 Unicode http://www.divcss5.com/jiqiao/j325.shtml */
            ol, ul, li {
                list-style: none
            }
    
            img {
                border: 0;
                vertical-align: middle
            }
    
            body {
                color: #000000;
                background: #FFF;
                text-align: center
            }
    
            .clear {
                clear: both;
                height: 1px;
                width: 100%;
                overflow: hidden;
                margin-top: -1px
            }
    
            a {
                color: #000000;
                text-decoration: none
            }
    
            a:hover {
                color: #BA2636
            }
    
            .red, .red a {
                color: #F00
            }
    
            .lan, .lan a {
                color: #1E51A2
            }
    
            .pd5 {
                padding-top: 5px
            }
    
            .dis {
                display: block
            }
    
            .undis {
                display: none
            }
    
            ul#nav {
                width: 100%;
                height: 60px;
                background: #00A2CA;
                margin: 0 auto
            }
    
            ul#nav li {
                display: inline;
                height: 60px
            }
    
            ul#nav li a {
                display: inline-block;
                padding: 0 20px;
                height: 60px;
                line-height: 60px;
                color: #FFF;
                font-family: "5FAE8F6F96C59ED1";
                font-size: 16px
            }
    
            ul#nav li a:hover {
                background: #0095BB
            }
    
    
        </style>
    </head>
    <body>
    <ul id="nav">
    <li><a href="http://www.divcss5.com/">首页</a></li>
    <li><a href="http://www.divcss5.com/html/">HTML教程</a></li>
    <li><a href="http://www.divcss5.com/rumen/">CSS基础</a></li>
    <li><a href="http://www.divcss5.com/css-tool/">CSS开发工具</a></li>
    <li><a href="http://www.divcss5.com/css-texiao/">CSS特效</a></li>
    <li><a href="http://www.divcss5.com/wenji/">CSS问题</a></li>
    </ul>
    <div>
        
        <p class="import">
            我是在子模板中
        </p>
    
    
    </div>
    </body>
    </html>
  • 相关阅读:
    编译Openmv固件&增加串口
    边缘 AI 平台的比较
    CVPR2021 | 重新思考BatchNorm中的Batch
    ICCV2021 |重新思考人群中的计数和定位:一个纯粹基于点的框架
    ICCV2021 | 重新思考视觉transformers的空间维度
    CVPR2021 | Transformer用于End-to-End视频实例分割
    漫谈CUDA优化
    AAAI 2021 最佳论文公布
    综述专栏 | 姿态估计综述
    为什么GEMM是深度学习的核心
  • 原文地址:https://www.cnblogs.com/liuruitao/p/7787587.html
Copyright © 2011-2022 走看看