首頁 > 軟體

Python模板的使用詳細講解

2022-10-16 14:01:53

一 模板語法傳值

方式一:

# urls.py
path('template', views.template)
# views.py
def template(request):
    name = "jasper"
    age = "18"
    return render(request, 'template.html', {"name": name, "age": age})

 <p>姓名:{{ name }}  年齡:{{ age }}</p>

方式二:關鍵字locals

def template(request):
    name = "jasper"
    age = "18"
    return render(request, 'template.html', locals())

傳值範圍:

  • 基本資料型別直接傳遞使用。
  • 函數名的傳遞會自動加括號執行並展示函數返回值(如果函數需要引數,則不會執行,也不會展示),模板語法不支援有參函數。
  • 類名的傳遞也會自動加括號產生物件。
  • 物件的傳遞則直接參照。

二 過濾器

add

{{ value|add:"2" }}

如果 value 是 4,那麼輸出將是 6。

這個過濾器將首先嚐試將兩個值強制轉為整數。如果失敗了,它將嘗試將兩個值加在一起。這對某些資料型別(字串、列表等)有效,而對其他型別則失敗。如果失敗,結果將是一個空字串。

capfirst

{{ value|capfirst }}

將值的第一個字元大寫。如果第一個字元不是字母,這個過濾器就沒有效果。

如果 value 是 “django”,則輸出為 “Django”。

center

在給定寬度的欄位中使數值居中。

"{{ value|center:"15" }}"

如果 value 是 “Django”,輸出將是 " Django "。

cut

從給定的字串中刪除引數的所有值。

{{ value|cut:" " }}

如果 value 是 “String with spaces”,輸出將是 “Stringwithspaces”。

date

根據給定的格式設定日期。

例子:

{{ value|date:"D d M Y" }}

如果 value 是一個 datetime 物件(例如,datetime.datetime.datetime.now() 的結果),輸出將是字串 ‘Wed 09 Jan 2008’。

傳遞的格式可以是預定義的 DATE_FORMAT、DATETIME_FORMAT、SHORT_DATE_FORMAT 或 SHORT_DATETIME_FORMAT, 或者是使用上表中顯示的格式指定器的自定義格式。請注意,預定義的格式可能會根據當前的 locale 而有所不同。

假設 USE_L10N 為 True 和 LANGUAGE_CODE 為例如 “es”,那麼對於:

{{ value|date:"SHORT_DATE_FORMAT" }}

輸出將是字串 “09/01/2008” (Django 自帶的 “SHORT_DATE_FORMAT” 格式指定符是 “d/m/Y”)。

當不使用格式字串時,使用 DATE_FORMAT 格式指定器。假設設定與前一個例子相同:

{{ value|date }}

輸出 9 de Enero de 2008 (DATE_FORMAT’ 格式指定符為 r’jde Fde Y’)。“d” 和 “e” 都是反斜槓,因為否則每一個都是一個格式字串,分別顯示日期和時區名稱。

你可以將 date 與 time 過濾器結合起來,以呈現一個 datetime 值的完整表示。例如:

{{ value|date:"D d M Y" }} {{ value|time:"H:i" }}

default

如果值為 False,則使用給定的預設值。否則,使用該值。 例子:

{{ value|default:"nothing" }}

如果 value 是 “” (空字串),輸出將是 nothing。

更多內建過濾器請檢視官方檔案:https://docs.djangoproject.com/zh-hans/4.1/ref/templates/builtins/

三 標籤

參考官方檔案:https://docs.djangoproject.com/zh-hans/4.1/ref/templates/builtins/

四 自定義模板標籤和過濾器

Django 模板語言套件含了很多 內建 tags 和 filters,設計目的是滿足應用需要佔位邏輯需求。極少情況下,你可能發現需要的功能未被核心模板集覆蓋。你能通過 Python 程式碼自定義 tags 和 filters 擴充套件整合模板引擎,通過 {% load %} 標籤使其可用。

該應用應包含一個 templatetags 目錄,與 models.py, views.py 等同級。若該目錄不存在,建立它——不要忘了用 init.py 檔案確保目錄被視作一個 Python 包。

自定義的 tags 和 filters 會儲存在模組名為 templatetags 的目錄內。模組檔案的名字即稍候你用來載入 tags 的名字,所以小心不要採用一個可能與其它應用自定義的 tags 和 filters 衝突的名字。

為了使 {% load %} 標籤生效,包含自定義標籤的應用必須包含在 INSTALLED_APPS 中。這是個安全特性:它允許你在一個主機上持有多個模板庫,而不是讓每個 Django 安裝都能存取所有的庫。

我們並未限制放入 templatetags 包中的模組數量。只需牢記 {% load %} 語句會載入名字指定 Python 模組的 tags/filters,而不是應用。

要成為一個可用的 tag 庫,模組必須包含一個名為 register 的模組級變數,它是一個 template.Library 範例。所有的 tags 和 filters 均在其中註冊。所以,在模組的開始,輸入以下內容:

from django import template
register = template.Library()

4.1 自定義過濾器

@register.filter(name='myfilter')
def my_add(a, b):
    return a + b

4.2 自定義標籤函數

@register.simple_tag(name='mt')
def func(a, b, c, d):
    return a + b + c + d

4.3 自定義inclusion_tag

@register.inclusion_tag(filename='it.html')
def index(n):
    html = []
    for i in range(n):
        html.append('第%s頁'%i)
    return locals()

參考官方檔案:https://docs.djangoproject.com/zh-hans/4.1/howto/custom-template-tags/

五 模板的繼承

# 在html頁面打上標記
{% block 名字 %}
    html標籤
{% endblock %}

# 擴充套件html介面
{% extends 'html檔案' %}

{% block 名字 %}
    html標籤
{% endblock %}

# 一般情況下模板中至少應該有三個區域
css、js、content

子板中還可以使用母板的內容 {{ block.super }}

六 模板的匯入

將html頁面的某個部分當做模組的形式匯入使用

{% include 'menu.html' %}

到此這篇關於Python模板的使用詳細講解的文章就介紹到這了,更多相關Python模板內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com