天天看點

Django(二):Django 模闆二、Django 模闆

二、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",],如下所示:

Django(二):Django 模闆二、Django 模闆

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,可以看到頁面:

Django(二):Django 模闆二、Django 模闆

此時,已完成了使用模闆來輸出資料,進而實作資料與視圖分離。

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,輸出結果如下:

Django(二):Django 模闆二、Django 模闆