Python知識(shí)分享網(wǎng) - 專業(yè)的Python學(xué)習(xí)網(wǎng)站 學(xué)Python,上Python222
Python Django 模版全解與實(shí)戰(zhàn)
發(fā)布于:2023-07-10 12:58:49

本文首先介紹了Django模板系統(tǒng)的基礎(chǔ)知識(shí),接著探討了如何安裝和配置Django模板系統(tǒng),然后深入解析了Django模板的基本結(jié)構(gòu)、標(biāo)簽和過濾器的用法,闡述了如何在模板中展示模型數(shù)據(jù),最后使用一個(gè)實(shí)際項(xiàng)目的例子來演示如何在實(shí)際開發(fā)中使用Django模板系統(tǒng)。

 

Django模板系統(tǒng)的簡(jiǎn)介

Django模板系統(tǒng)是一個(gè)強(qiáng)大的組件,它允許我們根據(jù)所提供的數(shù)據(jù)動(dòng)態(tài)生成HTML、XML等結(jié)構(gòu)化文本。模板系統(tǒng)不僅易于使用,且功能豐富。它包括一個(gè)內(nèi)置的語言:Django模板語言 (DTL),這是一種簡(jiǎn)單、非侵入式的語言,用于定義模板的結(jié)構(gòu)和邏輯。

例如,在一個(gè)Django模板中,我們可以使用變量和標(biāo)簽來動(dòng)態(tài)地生成內(nèi)容:

 

# Django模板示例
{{ book.title }} <!-- 輸出: Python編程基礎(chǔ) -->
{% if user.is_authenticated %} <!-- 如果用戶已登錄 -->
  Hello, {{ user.username }}! <!-- 輸出: Hello, John! -->
{% endif %}

 

以上代碼中,花括號(hào){{ }}用于輸出變量的值,標(biāo)簽{% %}用于執(zhí)行邏輯操作。


 

模板的基本結(jié)構(gòu)

Django模板是由一系列特殊的語法構(gòu)成的文本文件,用于動(dòng)態(tài)生成HTML、XML或其他標(biāo)記語言。下面我們來詳細(xì)了解一下Django模板的基本結(jié)構(gòu)。

 

模板語法

Django模板主要使用兩種語法:

  • 變量:用雙大括號(hào)({{ }})包裹。比如{{ variable }},Django將會(huì)將其替換為變量的值。
  • 標(biāo)簽:用大括號(hào)和百分號(hào)({% %})包裹。標(biāo)簽提供了模板的控制結(jié)構(gòu),比如循環(huán)、條件語句等。比如{% for item in list %}...{% endfor %}。

 

模板繼承

Django模板系統(tǒng)支持模板繼承。這是一種DRY(Don't Repeat Yourself)的設(shè)計(jì)原則。你可以定義一個(gè)基礎(chǔ)模板(base template),然后讓其他模板繼承這個(gè)基礎(chǔ)模板并覆蓋其中的某些部分。

例如,定義一個(gè)基礎(chǔ)模板base.html

 

<!-- base.html -->
<html>
<body>
{% block content %}{% endblock %}
</body>
</html>

 

然后,定義一個(gè)子模板child.html,繼承base.html并覆蓋content塊:

 

<!-- child.html -->
{% extends "base.html" %}

{% block content %}
<p>Hello, Django!</p>
{% endblock %}

 

其他模板

除了繼承,Django模板還支持包含(include)其他模板,這可以幫助你將模板分解為小的、可重用的部分。

例如,定義一個(gè)模板header.html

 

<!-- header.html -->
<header>
  <h1>Welcome to My Website</h1>
</header>

 

然后,在另一個(gè)模板中包含這個(gè)模板:

 

{% include "header.html" %}

<p>This is the main content...</p>

 

配置Django模板

 

配置Django模板系統(tǒng)

Django模板系統(tǒng)默認(rèn)已經(jīng)被包含在Django項(xiàng)目中。你可以在項(xiàng)目的settings.py文件中找到模板的配置信息:

 

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [BASE_DIR / 'templates'],
        ...
    },
]

 

你可以在'DIRS'配置項(xiàng)中添加模板的路徑。默認(rèn)情況下,Django會(huì)在每個(gè)應(yīng)用的templates目錄下查找模板文件。

 

配置模板加載方式

Django模板系統(tǒng)可以從多個(gè)位置加載模板。默認(rèn)情況下,Django會(huì)在每個(gè)應(yīng)用的templates目錄下查找模板文件。你可以通過修改TEMPLATES配置中的'DIRS'選項(xiàng)來添加其他模板目錄。例如,你可以添加一個(gè)全局的模板目錄:

 

# settings.py

import os
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

TEMPLATES = [
    {
        ...
        'DIRS': [os.path.join(BASE_DIR, 'templates')],
        ...
    },
]

 

 

在此配置中,所有的模板文件都會(huì)在項(xiàng)目根目錄下的templates文件夾中查找。

 

配置模板引擎

TEMPLATES配置中,'BACKEND'選項(xiàng)用于指定使用哪個(gè)模板引擎。Django默認(rèn)使用的是自帶的模板引擎,即django.template.backends.django.DjangoTemplates。你也可以切換到其他模板引擎,例如Jinja2:

 

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.jinja2.Jinja2',
        ...
    },
]

 

注意,不同的模板引擎可能需要不同的配置,并且提供的模板語言也可能不同。

 

配置自定義模板標(biāo)簽和過濾器

如果你有自定義的模板標(biāo)簽和過濾器,你需要把它們放在某個(gè)應(yīng)用下的templatetags目錄中。然后在INSTALLED_APPS配置中添加該應(yīng)用,Django就會(huì)自動(dòng)加載你的自定義模板標(biāo)簽和過濾器:

 

# settings.py

INSTALLED_APPS = [
    ...
    'myapp',
    ...
]

 

模板標(biāo)簽詳解

Django模板系統(tǒng)中的標(biāo)簽(Tags)提供了各種控制結(jié)構(gòu),包括循環(huán)、條件語句、模板繼承等。接下來我們?cè)敿?xì)介紹一些常用的標(biāo)簽。

 

for標(biāo)簽

for標(biāo)簽用于在模板中循環(huán)遍歷序列:

 

{% for item in item_list %}
    <p>{{ item.name }}</p> <!-- 輸出每個(gè)項(xiàng)目的名稱 -->
{% endfor %}

 

if標(biāo)簽

if標(biāo)簽用于條件判斷。你可以使用elifelse進(jìn)行多分支判斷:

 

{% if user.is_authenticated %}
    <p>Welcome back, {{ user.username }}.</p> <!-- 如果用戶已經(jīng)認(rèn)證,打印歡迎信息 -->
{% else %}
    <p>Please log in.</p> <!-- 如果用戶未認(rèn)證,提示用戶登錄 -->
{% endif %}

 

extends標(biāo)簽和block標(biāo)簽

extends標(biāo)簽用于模板繼承,block標(biāo)簽用于定義可被子模板覆蓋的區(qū)塊:

 

<!-- base.html -->
<html>
<body>
{% block content %}{% endblock %}
</body>
</html>

<!-- child.html -->
{% extends "base.html" %}

{% block content %}
<p>Hello, Django!</p>
{% endblock %}

 

include標(biāo)簽

include標(biāo)簽用于包含其他模板,使得模板可重用:

 

{% include "header.html" %}

 

url標(biāo)簽

url標(biāo)簽用于生成URL。它接受一個(gè)視圖函數(shù)的名稱或URL模式的名稱,以及可選的參數(shù),然后返回對(duì)應(yīng)的URL:

 

<a href="{% url 'home' %}">Home</a> <!-- 生成首頁的URL -->

 

csrf_token標(biāo)簽

在使用POST表單時(shí),csrf_token標(biāo)簽用于生成CSRF令牌,以防止跨站請(qǐng)求偽造攻擊:

 

<form method="post">
{% csrf_token %}
<!-- 表單內(nèi)容 -->
</form>

 

模板過濾器

在Django模板中,過濾器可以在變量被顯示之前對(duì)其進(jìn)行修改。過濾器的語法是在變量名后面添加一個(gè)豎線(|)和過濾器的名稱。如果過濾器需要參數(shù),可以使用冒號(hào)(:)添加。讓我們?cè)敿?xì)了解一下。

 

基本使用

比如,我們可以使用date過濾器來格式化日期:

 

{{ date_var|date:"F j, Y" }} <!-- 輸出: July 8, 2023 -->

 

使用lower過濾器將文本轉(zhuǎn)換為小寫:

 

{{ "Hello World"|lower }} <!-- 輸出: hello world -->

 

鏈接過濾器

你還可以鏈接多個(gè)過濾器,他們會(huì)按照從左到右的順序執(zhí)行:

 

{{ "Hello World"|lower|capfirst }} <!-- 輸出: Hello world -->

 

自定義過濾器

除了使用Django內(nèi)置的過濾器,你還可以創(chuàng)建自己的過濾器。為此,你需要在某個(gè)應(yīng)用下的templatetags目錄中創(chuàng)建一個(gè)Python文件,然后在其中定義你的過濾器函數(shù),并使用register.filter裝飾器注冊(cè)它:

 

from django import template

register = template.Library()

@register.filter
def my_filter(value):
    # 這是一個(gè)簡(jiǎn)單的過濾器,它返回值的第一個(gè)字符
    return value[0]

 

然后你就可以在模板中使用這個(gè)過濾器了:

 

{{ "Hello World"|my_filter }} <!-- 輸出: H -->

 

Django模板中展示模型數(shù)據(jù)

Django框架將模型數(shù)據(jù)和模板視圖分離,這讓我們?cè)谀0逯蟹奖愕卣故灸P蛿?shù)據(jù)。在視圖函數(shù)中,我們可以查詢模型數(shù)據(jù),然后將它傳遞給模板。在模板中,我們使用特殊的語法來訪問和展示這些數(shù)據(jù)。

 

在視圖中準(zhǔn)備數(shù)據(jù)

假設(shè)我們有一個(gè)Blog模型,它有一個(gè)title字段和一個(gè)content字段。在我們的視圖函數(shù)中,我們可以查詢所有的博客:

 

from django.shortcuts import render
from .models import Blog

def blog_list(request):
    blogs = Blog.objects.all()  # 查詢所有的博客
    return render(request, 'blog_list.html', {'blogs': blogs})

 

在模板中展示數(shù)據(jù)

然后,在我們的blog_list.html模板中,我們可以使用for標(biāo)簽來遍歷所有的博客,并使用變量語法來展示每個(gè)博客的標(biāo)題和內(nèi)容:

 

{% for blog in blogs %}
<h2>{{ blog.title }}</h2>  <!-- 展示博客標(biāo)題 -->
<p>{{ blog.content }}</p>  <!-- 展示博客內(nèi)容 -->
{% endfor %}

 

使用過濾器格式化數(shù)據(jù)

在模板中,我們還可以使用過濾器來對(duì)模型數(shù)據(jù)進(jìn)行格式化。例如,我們可以使用date過濾器來格式化日期,或者使用truncatechars過濾器來限制文本的長(zhǎng)度:

 

{% for blog in blogs %}
<h2>{{ blog.title }}</h2>
<p>{{ blog.publish_date|date:"F j, Y" }}</p>  <!-- 使用date過濾器格式化發(fā)布日期 -->
<p>{{ blog.content|truncatechars:100 }}</p>  <!-- 使用truncatechars過濾器限制內(nèi)容長(zhǎng)度 -->
{% endfor %}

 

在實(shí)際的項(xiàng)目中使用Django模板

Django模板系統(tǒng)在實(shí)際的項(xiàng)目開發(fā)中扮演著重要的角色。下面我們就以一個(gè)簡(jiǎn)單的博客系統(tǒng)作為例子,演示如何在實(shí)際項(xiàng)目中使用Django模板。

 

第一步:定義你的模型

首先,我們需要在我們的應(yīng)用中定義一個(gè)模型。在這個(gè)例子中,我們定義一個(gè)Post模型來表示博客文章:

 

from django.db import models

class Post(models.Model):
    title = models.CharField(max_length=200)  # 文章標(biāo)題
    content = models.TextField()  # 文章內(nèi)容
    pub_date = models.DateTimeField(auto_now_add=True)  # 發(fā)布日期

 

第二步:創(chuàng)建視圖

接著,我們需要?jiǎng)?chuàng)建一個(gè)視圖來處理用戶的請(qǐng)求。在這個(gè)視圖中,我們可以獲取所有的博客文章,并將它們傳遞給模板:

 

from django.shortcuts import render
from .models import Post

def post_list(request):
    posts = Post.objects.all()  # 獲取所有的博客文章
    return render(request, 'blog/post_list.html', {'posts': posts})  # 將文章傳遞給模板

 

第三步:編寫模板

然后,我們可以創(chuàng)建一個(gè)模板來展示博客文章。在這個(gè)模板中,我們使用for標(biāo)簽來遍歷所有的文章,并使用變量來展示文章的標(biāo)題和內(nèi)容:

 

{% for post in posts %}
<h2>{{ post.title }}</h2>
<p>{{ post.content }}</p>
<p>Published on {{ post.pub_date|date:"F j, Y" }}</p>
{% endfor %}

 

第四步:配置URLs

最后,我們需要在urls.py文件中配置URL,使得用戶可以訪問我們的視圖:

 

from django.urls import path
from . import views

urlpatterns = [
    path('posts/', views.post_list, name='post_list'),  # 當(dāng)用戶訪問/posts/時(shí),顯示博客文章列表
]

 

以上就是在實(shí)際項(xiàng)目中使用Django模板的基本步驟。通過這個(gè)例子,我們可以看到Django模板系統(tǒng)的強(qiáng)大和靈活性,它可以幫助我們快速地創(chuàng)建動(dòng)態(tài)的網(wǎng)頁。

轉(zhuǎn)載自:https://www.cnblogs.com/xfuture/p/17537479.html