二、Django 模闆
使用 django.http.HttpResponse() 來輸出 “Hello World!”,該方式将資料與視圖混合在一起,不符合 Django 的 MVC 思想。
本節詳細介紹 Django 模闆的應用,模闆是一個文本,用于分離文檔的表現形式和内容。
1. 模闆應用執行個體
1)建立 hello.html 檔案
在 HelloWorld 目錄底下建立 templates 目錄并建立 hello.html 檔案。
hello.html 檔案代碼如下:
<h1>{{ hello }}</h1>
變量在模闆中使用雙括号。
2)編輯 settings.py 檔案
向 Django 說明模闆檔案的路徑,編輯 HelloWorld/settings.py,修改 TEMPLATES 中的 DIRS 為 [BASE_DIR+"/templates",],如下所示:
![](https://img.laitimes.com/img/9ZDMuAjOiMmIsIjOiQnIsICM38FdsYkRGZkRG9lcvx2bjxiNx8VZ6l2cs0TPR9UeFpmT6FFVPpHOsJGcohVYsR2MMBjVtJWd0ckW65UbM5WOHJWa5kHT20ESjBjUIF2X0hXZ0xCMx81dvRWYoNHLrdEZwZ1Rh5WNXp1bwNjW1ZUba9VZwlHdssmch1mclRXY39CXldWYtlWPzNXZj9mcw1ycz9WL49zROBlL1czNxUzM0EjMzIjNwkTMwIzLc52YucWbp5GZzNmLn9Gbi1yZtl2Lc9CX6MHc0RHaiojIsJye.png)
3)編輯 view.py 檔案
修改 view.py,增加一個新的對象,用于向模闆送出資料:
from django.shortcuts import render
def hello(request):
context = {}
context['hello'] = 'Hello World!'
return render(request, 'hello.html', context)
這裡使用 render 來替代之前使用的 HttpResponse,render 使用了一個字典 context 作為參數,context 字典中元素的鍵值 ‘hello’ 對應了模闆中的變量 ‘{{ hello }}’。
4)測試
通路位址:http://127.0.0.1:8000/hello,可以看到頁面:
此時,已完成了使用模闆來輸出資料,進而實作資料與視圖分離。
2. Django 模闆标簽
1)if/else 标簽
基本文法格式如下:
if:
{% if condition %}
... display
{% endif %}
if/elif/else:
{% if condition1 %}
... display 1
{% elif condiiton2 %}
... display 2
{% else %}
... display 3
{% endif %}
根據條件判斷是否輸出。
if/else 支援嵌套。
{% if %} 标簽接受 and , or 或者 not 關鍵字來對多個變量做判斷 ,或者對變量取反(not),例如:
{% if athlete_list and coach_list %}
athletes 和 coaches 變量都是可用的。
{% endif %}
2)for 标簽
基本文法格式如下:
{% for %}
...
{% endfor %}
允許在一個序列上疊代。
與 Python 的 for 語句的情形類似,循環文法是 for X in Y ,Y 是要疊代的序列而X是在每一個特定的循環中使用的變量名稱。
每一次循環中,模闆系統會渲染在 {% for %} 和 {% endfor %} 之間的所有内容。
例如,給定一個運動員清單 athlete_list 變量,我們可以使用下面的代碼來顯示這個清單:
<ul>
{% for athlete in athlete_list %}
<li>{{ athlete.name }}</li>
{% endfor %}
</ul>
給标簽增加一個 reversed 使得該清單被反向疊代:
{% for athlete in athlete_list reversed %}
...
{% endfor %}
可以嵌套使用 {% for %} 标簽:
{% for athlete in athlete_list %}
<h1>{{ athlete.name }}</h1>
<ul>
{% for sport in athlete.sports_played %}
<li>{{ sport }}</li>
{% endfor %}
</ul>
{% endfor %}
3)ifequal/ifnotequal 标簽
{% ifequal %} 标簽比較兩個值,當他們相等時,顯示在 {% ifequal %} 和 {% endifequal %} 之中所有的值。
下面的例子比較兩個模闆變量 user 和 currentuser :
{% ifequal user currentuser %}
<h1>Welcome!</h1>
{% endifequal %}
和 {% if %} 類似, {% ifequal %} 支援可選的 {% else%} 标簽:
{% ifequal section 'sitenews' %}
<h1>Site News</h1>
{% else %}
<h1>No News Here</h1>
{% endifequal %}
4)注釋标簽
Django 注釋使用 {# #}。
{# 這是一個注釋 #}
5)過濾器
模闆過濾器可以在變量被顯示前修改它,過濾器使用管道字元,如下所示:
{{ name|lower }}
{{ name }} 變量被過濾器 lower 處理後,文檔大寫轉換文本為小寫。
過濾管道可以被 * 套接 * ,既是說,一個過濾器管道的輸出又可以作為下一個管道的輸入:
{{ my_list|first|upper }}
以上執行個體将第一個元素并将其轉化為大寫。
有些過濾器有參數,過濾器的參數跟随冒号之後并且總是以雙引号包含。 例如:
{{ bio|truncatewords:"30" }}
這個将顯示變量 bio 的前30個詞。
其他過濾器:
- addslashes : 添加反斜杠到任何反斜杠、單引号或者雙引号前面。
- date : 按指定的格式字元串參數格式化 date 或者 datetime 對象,執行個體:
{{ pub_date|date:"F j, Y" }}
-
length : 傳回變量的長度。
6)include 标簽
{% include %} 标簽允許在模闆中包含其它的模闆的内容。
下面這個例子都包含了 nav.html 模闆:
{% include "nav.html" %}
3. 模闆繼承
模闆可以用繼承的方式來實作複用。
1)建立原始檔案
在項目的 templates 目錄中添加 base.html 檔案,代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>測試</title>
</head>
<body>
<h1>Hello World!</h1>
<p>Django 測試</p>
{% block mainbody %}
<p>original</p>
{% endblock %}
</body>
</html>
以上代碼中,名為 mainbody 的 block 标簽是可以被繼承者們替換掉的部分。
所有的 {% block %} 标簽告訴模闆引擎,子模闆可以重載這些部分。
2)繼承原始檔案
hello.html 中繼承 base.html,并替換特定 block,hello.html 修改後的代碼如下:
{% extends "base.html" %}
{% block mainbody %}
<p>繼承了 base.html 檔案</p>
{% endblock %}
3)測試
通路位址 http://127.0.0.1:8000,輸出結果如下: