1. 程式人生 > >django template 基礎(二)(在檢視中使用模板)

django template 基礎(二)(在檢視中使用模板)

在檢視中使用模板2

前序

在學習了模板系統的基礎之後,現在讓我們使用相關知識來建立檢視。
先看一下沒有使用template的檢視程式碼

from django.http import HttpResponse
import datetime

def current_datetime(request):
    now = datetime.datetime.now()
    html = "<html><body>It is now %s.</body></html>" % now
    return HttpResponse(html)

用 Django模板系統來修改該檢視。

step 1 新增模板路徑

在settings.py中找到

TEMPLATE_DIRS = (
    # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates".
    # Always use forward slashes, even on Windows.
    # Don't forget to use absolute paths, not relative paths.
)

把配置改成(如果沒有這個引數 ,直接新增):

TEMPLATE_DIRS = (
    'E:/python_workspace/sfweb/sfweb/books/templates'
, )

或者:

import os.path
TEMPLATE_DIRS = (
    os.path.join(os.path.dirname(__file__), 'templates').replace('\\','/'),
)

下面是一些注意事項:

  • Python 要求單元素元組中必須使用逗號,以此消除與圓括號表示式之間的歧義
  • Windows 平臺,驅動器符號也要使用Unix風格的斜槓(/)而不是反斜槓

step 2 修改檢視程式碼

返回 current_datetime 檢視,進行如下修改:

from django.shortcuts import render ,render_to_response
from
django.http import HttpResponse from django.template.loader import get_template #from django.template import Context,Template import datetime def current_datetime(request): now = datetime.datetime.now() # t = get_template("ctime.html") ##get_template() 方法可以直接得到Template 例項 #ctx = Context({'now':now}) #html = t.render({'now':now}) return render_to_response("ctime.html", locals()) # render_to_response 封裝了get_template()方法,

注意:

  • locals() 返回所有區域性變數的名稱與值進行對映。
  • 如果 get_template() 找不到給定名稱的模板,將會引發一個 TemplateDoesNotExist 異常

step 3 建立模板

在模板目錄E:/python_workspace/sfweb/sfweb/books/templates 建立 current_datetime.html 檔案
內容:

<html><body>It is now {{ current_date }}.</body></html>

高階模板

1 內建模板標籤
{% include ‘current_datetime.html ’ %} :在新的html中嵌入current_datetime.html
2 模板繼承
本質上來說,模板繼承就是先構造一個基礎框架模板,而後在其子模板中對它所包含站點公用部分和定義塊進行過載。
第一步是定義 基礎模板 , 該框架之後將由 子模板 所繼承。 以下是我們目前所講述範例的基礎模板:9

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN">
<html lang="en">
<head>
    <title>{% block title %}{% endblock %}</title>
</head>
<body>
    <h1>My helpful timestamp site</h1>
    {% block content %}{% endblock %}
    {% block footer %}
    <hr>
    <p>Thanks for visiting my site.</p>
    {% endblock %}
</body>
</html>

{% block %}標籤所要做的是告訴模板引擎,該模板下的這一塊內容將有可能被子模板覆蓋

現在我們已經有了一個基本模板,我們可以修改 current_datetime.html 模板來繼承base.html

{% extends "base.html" %}{% block title %}The current time{% endblock %}{% block content %}
<p>It is now {{ current_date }}.</p>
{% endblock %}

模板引擎發現了 {% extends %} 標籤, 注意到該模板是一個子模板。 模板引擎立即裝載其父模板,即本例中的 base.html 。
你可以根據需要使用任意多的繼承次數。 使用繼承的一種常見方式是下面的三層法:

  1. 建立 base.html 模板,在其中定義站點的主要外觀感受。 這些都是不常修改甚至從不修改的部分。
  2. 為網站的每個區域建立 base_SECTION.html 模板(例如, base_photos.html 和
    base_forum.html )。這些模板對 base.html 進行拓展,幷包含區域特定的風格與設計
  3. 為每種型別的頁面建立獨立的模板,例如論壇頁面或者圖片庫。 這些模板拓展相應的區域模板。

以下是使用模板繼承的一些訣竅:
如果在模板中使用 {% extends %} ,必須保證其為模板中的第一個模板標記。 否則,模板繼承將不起作用。3

一般來說,基礎模板中的 {% block %} 標籤越多越好。 記住,子模板不必定義父模板中所有的程式碼塊,因此你可以用合理的預設值對一些程式碼塊進行填充,然後只對子模板所需的程式碼塊進行(重)定義。 俗話說,鉤子越多越好。4

如果發覺自己在多個模板之間拷貝程式碼,你應該考慮將該程式碼段放置到父模板的某個 {% block %} 中。

如果你需要訪問父模板中的塊的內容,使用 {{ block.super }}這個標籤吧,這一個魔法變數將會表現出父模板中的內容。 如果只想在上級程式碼塊基礎上新增內容,而不是全部過載,該變數就顯得非常有用了。17

不允許在同一個模板中定義多個同名的 {% block %} 。 存在這樣的限制是因為block 標籤的工作方式是雙向的。 也就是說,block 標籤不僅挖了一個要填的坑,也定義了在父模板中這個坑所填充的內容。如果模板中出現了兩個相同名稱的 {% block %} 標籤,父模板將無從得知要使用哪個塊的內容。4

{% extends %} 對所傳入模板名稱使用的載入方法和 get_template() 相同。 也就是說,會將模板名稱被新增到 TEMPLATE_DIRS 設定之後。4

多數情況下, {% extends %} 的引數應該是字串,但是如果直到執行時方能確定父模板名,這個引數也可以是個變數。 這使得你能夠實現一些很酷的動態功能。