Flask入門之模板導入與塊巨集(六)

来源:https://www.cnblogs.com/why957/archive/2018/06/01/9123248.html
-Advertisement-
Play Games

1 模板包含include 主體結構 (導入整個模板,直接渲染不可修改) {% include('模板名稱') %} {% include('目錄/模板名稱') %} 功能: 其功能就是將另一個模板載入到當前模板中,並直接渲染在當前位置上,而且是一次渲染整個模塊內容 註意: 當include模板文件 ...


1 模板包含include

主體結構(導入整個模板,直接渲染不可修改)

{% include('模板名稱') %}

{% include('目錄/模板名稱') %}

功能: 其功能就是將另一個模板載入到當前模板中,並直接渲染在當前位置上,而且是一次渲染整個模塊內容

#導入頭部header.html
{% include 'header.html' %}
    主體內容
#導入底部footer.html
{% include 'footer.html' %}

#忽略模板文件不存在時的錯誤
{% include 'footer.html' ignore missing %}

#也可以組成模板列表,會按照順序依次載入
{% include ['footer.html','bottom.html','end.html'] ignore missing %}

註意:當include模板文件不存在時,程式會拋出異常,加上ignore missing關鍵字可以忽略不存在時的異常.

2 巨集(macro)

概念 : Jinja2中巨集的功能類似python中函數定義,分為聲明與調用兩個部分

(1) 巨集的定義

主體結構

{% macro 巨集的名稱([參數...s]) %}

​ 巨集的主體

{% endmacro %}

巨集的調用

{{ 巨集的名稱[參數列表] }}

(2) 巨集的實例1

templates/common/formmacro.html

{% macro input(type='text',name='',value='') %}
    <input type="{{ type }}" name="{{ name }}" value="{{ value }}">
{% endmacro %}

先導入後調用

{% import 'common/formmacro.html' as formmacro %}
<form action=''>
    <p>用戶名:{{ formmacro.input(name='uername') }}</p>
    <p>密碼:{{ formmacro.input('password','userpass') }}</p>
      <p>性別:
        {{ formmacro.input('radio','sex',1) }} 男
        {{ formmacro.input('radio','sex',0) }} 女
      </p>
      <p>{{ formmacro.input('submit',value='submit') }}</p>
</form>

(3) 巨集的實例2

#定義一個users巨集,輸出user.name  caller(user.gender)傳遞參數
{% macro list_users(users) -%}
  <table>
    {%- for user in users %}
      <tr><td>{{ user.name |e }}</td>{{ caller(user.gender) }}</tr>
    {%- endfor %}
  </table>
{%- endmacro %}

#調用巨集,{{ caller(user.gender) }}”部分被調用者”{% call(gender) %}”語句塊內部的內容替代
{% call(gender) list_users(users) %}
    <td>
    {% if gender == 'M' %}
    <img src="{{ url_for('static', filename='img/male.png') }}" width="20px">
    {% else %}
    <img src="{{ url_for('static', filename='img/female.png') }}" width="20px">
    {% endif %}
    </td>
    <td><input name="delete" type="button" value="Delete"></td>
{% endcall %}

(4)import 導入:(針對導入巨集或者自定義的巨集)

import ....as....

{% import 'common/formmacro.html' as formmacro %}
如果index.html和formmacro同級 可以直接導入
{% import 'formmacro.html' as formmacro %}

from ... import as

{% from 'common/formmacro.html' import input %}   #從包導入巨集
{% from 'common/formmacro.html' import input as form %}  #從包導入巨集並重命名

註意:

  1. 不能在巨集定義的上方去調用
  2. 巨集如果存在形參 如果不傳實參 則行參的值為空 也不會報錯
  3. 在給形參預設值的時候 必須遵循預設值的規則 幽預設值的放在後面 和 python的函數一樣

(5) 巨集的內部變數

varargs : 這是一個列表。如果調用巨集時傳入的參數多於巨集聲明時的參數,多出來的沒指定參數名的參數就會保存在這個列表中。

kwargs : 這是一個字典。如果調用巨集時傳入的參數多於巨集聲明時的參數,多出來的指定了參數名的參數就會保存在這個字典中。

{% macro input(name, type='text', value='') %}
    <input type="{{ type }}" name="{{ name }}" value="{{ value|e }}">
    <br /> {{ varargs }}
    <br /> {{ kwargs }}
{% endmacro %}
<p>{{ input('submit', 'submit', 'Submit', 'more arg1', 'more arg2', ext='more arg3') }}</p>

3 塊(block)

主體結構:一般結合繼承使用,用於填充block塊

{% extend ‘parent.html’ %}

{% block block_name %}
{% endblock 塊名%}

註意:

  1. 模板不支持多繼承,也就是子模板中定義的塊,不可能同時被兩個父模板替換。
  2. 模板中不能定義多個同名的塊,子模板和父模板都不行,這樣無法知道要替換哪一個部分的內容。

(1) 保留父模板中的內容採用 super( )方法

  • python #父模板中設置好塊 <head> {% block head %} <link rel="stylesheet" href="{{ url_for('static', filename='style.css') }}"> <title>{% block title %}{% endblock %}</title> {% endblock head%} </head> <body> <div class="page"> {% block content %} {% endblock %} </div> </body>

  • python {% block title %}首頁{% endblock %} {% block head %} {{ super() }} #繼承父類保持父類不變 <style type="text/css"> h1 { color: #336699; } </style> {% endblock %}

  • 註: 父模板與子模板中都有head塊,運行時,父模板中的塊先被載入,而後是子模板的塊head

(2) 塊內語句的作用域

預設情況下,塊內語句是無法訪問塊作用域外的變數

#父模板中
{% for item in range(5) %}
        <li>{% block list %}{% endblock %}</li>
{% endfor %}

#子模板繼承
{% block list %}
    <p>{{ item }}</p>
{% endblock %}

#此時子模板是無法獲取到父模板中 list塊中的內容,即列印為空

如果你想在塊內訪問這個塊外的變數,你就需要在塊聲明時添加scoped關鍵字

#父模板中添加 scoped 關鍵字
{% for item in range(5) %}
        <li>{% block list scoped %}{% endblock %}</li>
{% endfor %}

#子模板繼承
{% block list %}
    <p>{{ item }}</p>
{% endblock %}

#此時item能獲取到 0,1,2,3,4

4 模板的繼承

主體架構

{% extends '繼承的模板名稱' %}

{% block 替換的名稱 %}

{% endblock %}

自定義一個基類模板base.html

<!DOCTYPE html>
<html lang="en">
{% block head %}
<head>
    <meta charset="UTF-8">
    <title>{% block title %}{% endblock %}</title>  #title塊
    {% block meta %}{% endblock %}
    <style>
        {% block style %}   #css樣式塊
            *{color:red;}
        {% endblock %}
    </style>
    {% block link %}{% endblock %}  #外聯樣式塊
</head>
{% endblock %}
<body>
{% include 'common/header.html' %}  #頁面導入
{% block content %}

{% endblock %}
{% include 'common/footer.html' %}  #頁面導入
</body>
</html>

使用index.html繼承父類

{% extends 'common/base.html' %}   #繼承父類模板
{% block title %}首頁{% endblock %}
{% block style %}
    {# 調用基礎模板內的樣式  如果不調用則全部被覆蓋 #}
    {{ super() }}
    p{font-size:20px;}
{% endblock %}
{% block content %}
    我是中間的內容部分
{% endblock %}

註意:

  1. 在替換的外部的填寫的內容 不會被顯示出來
  2. 如果在替換某一個block的時候 替換以後所有的樣式消失 則去查看是否有調用super()

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、什麼是Java事務 通常的觀念認為,事務僅與資料庫相關。 事務必須服從ISO/IEC所制定的ACID原則。ACID是原子性(atomicity)、一致性(consistency)、隔離性 (isolation)和持久性(durability)的縮寫。事務的原子性表示事務執行過程中的任何失敗都將導 ...
  • 一、自定義標簽開發庫簡介: Tag介面的方法: 二、自定義標簽入門:輸出客戶機ip 1.編寫一個實現tag介面的java類 ViewIPTag.java 2.在tld文件中對標簽處理器類進行描述(tld文件的位置:WEB-INF下,可以抄apache-tomcat/webapps\examples\ ...
  • 1、Hibernate中實體類的創建規則是什麼? 2、hibernate中實體類的三種狀態? 三種狀態: 3、hibernate中的批量查詢的三種方式 4、填寫下麵級聯操作: 級聯保存:casecade=”save-update” 級聯刪除:casecade=”delete” 級聯保存+級聯刪除:c ...
  • public final class Array 成員方法: public static String toString(int[] a) 把數組轉成字元串 public static void sort(int[] a) 對數組進行排序 public static int binarySearch ...
  • Python數據類型之字典(Dictionary) 字典特征 1. 特征 可變、無序、映射、鍵值對 2. 形式 {key0:value0, key1:value1, key2:value3, ..., } key :唯一性,key的數據類型必須是固定不可變的,如數字、字元串、元組、凍結集合 valu ...
  • Java條件語句之 switch 當需要對選項進行等值判斷時,使用 switch 語句更加簡潔明瞭。例如:根據考試分數,給予前四名不同的獎品。第一名,獎勵筆記本一臺;第二名,獎勵 IPAD 2 一個;第三名,獎勵移動電源一個;最後一名獎勵 U 盤一個。 語法: 執行過程:當 switch 後表達式的 ...
  • 一,pycharm 1,在官網下載pycharm,版本選5.0,一定要下載專業版。 2,註冊方法:註冊時選擇 license server,填入:http//idea.qinxi1992.cn,然後點擊ok。 若不成功,則填入:http//idea.lanyus.com,然後點擊 ok。 3,創建新 ...
  • 實現Servlet容器(Servlet容器根據web.xml文件調用對應的Servlet類) Servlet(狹義解釋是Servlet介面,但更常見的解釋是實現Servlet的所有類) 介紹:Servlet容器是用來管理Servlet, 過程:瀏覽器輸入URL地址,伺服器接收到這個地址,根據瀏覽器的 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...