深入理解 Django 模板系统


概要

在任何 Web 开发过程中,渲染和展示数据是不可或缺的一部分。Django 作为一个高效的 Python Web 框架,提供了一个强大且灵活的模板系统。本文将详细介绍 Django 模板系统的核心概念、语法和高级功能。


一、Django 模板系统简介

Django 的模板系统允许开发者使用模板语言来生成动态 HTML 输出。模板包含变量,这些变量会被 Django 替换为实际的值,并且模板也包含标签,这些标签允许逻辑编程比如循环或判断。

二、基本使用

  1. 「创建模板」

假设你有一个名为 myapp 的 Django 应用,可以在该应用下创建一个名为 templates 的文件夹,并在其中创建模板文件,例如 index.html

复制代码
myapp/
├── templates/
│   └── index.html
└── ...
  1. 「编写模板」

index.html 文件中,你可以使用 Django 模板语言来创建动态内容。

复制代码
<html>
<body>
    <h1>Welcome {{ user.username }}</h1>
    <ul>
        {% for item in item_list %}
            <li>{{ item.name }}</li>
        {% endfor %}
    </ul>
</body>
</html>

在这个例子中,{``{ user.username }} 是一个变量,而 {% for item in item_list %} 是一个模板标签用于循环。

  1. 「渲染模板」

在你的 Django 视图中,你可以使用 render 函数来渲染模板。

复制代码
from django.shortcuts import render

def index(request):
    context = {'user': request.user, 'item_list': Item.objects.all()}
    return render(request, 'index.html', context)

三、模板继承

模板继承是 Django 模板系统中最强大的部分之一。

  1. 「基础模板」

创建一个基础模板 base.html,其中包含网站的共同结构和元素。

复制代码
<html>
<head>
    <title>{% block title %}My Website{% endblock %}</title>
</head>
<body>
    <header>
        <!-- 头部内容 -->
    </header>

    <main>
        {% block content %}{% endblock %}
    </main>

    <footer>
        <!-- 脚部内容 -->
    </footer>
</body>
</html>
  1. 「子模板」

在子模板中,你可以通过定义块(blocks)来重写基础模板中的内容。

复制代码
{% extends 'base.html' %}

{% block title %}Welcome Page{% endblock %}

{% block content %}
    <h1>Welcome {{ user.username }}</h1>
    <!-- 更多内容 -->
{% endblock %}

四、模板标签和过滤器

  1. 「标签(Tags)」

标签提供了在模板中插入逻辑的方式。例如 {% if user.is_authenticated %}{% for item in item_list %}

  1. 「过滤器(Filters)」

过滤器用于在变量被显示之前修改它们。例如,{``{ user.username|lower }} 会将用户名转换为小写。

五、自定义标签和过滤器

你也可以创建自己的模板标签和过滤器。

  1. 「创建自定义过滤器」

在你的 Django 应用中创建一个名为 templatetags 的文件夹,并在其中创建一个 Python 文件,例如 my_filters.py

复制代码
from django import template

register = template.Library()

@register.filter(name='cut')
def cut(value, arg):
    return value.replace(arg, '')

使用 {% load my_filters %} 来在模板中使用这个过滤器。

  1. 「创建自定义标签」

类似地,你可以在 templatetags 文件夹中创建自定义标签。

六、小结

Django 模板系统提供了一个非常强大且灵活的方式来创建动态的 HTML 页面。通过理解和掌握其核心概念和高级功能,你可以在 Web 开发中更加高效地工作。

相关推荐
wuqingshun3141592 分钟前
经典算法 (A/B) mod C
c语言·开发语言·c++·算法·蓝桥杯
半青年7 分钟前
Qt图表库推荐指南与分析
c语言·开发语言·javascript·c++·qt·信息可视化
艾米莉亚糖25 分钟前
解决qt.network.ssl: QSslSocket::connectToHostEncrypted: TLS initialization failed
开发语言·qt·ssl
CryptoRzz34 分钟前
股票数据源对接技术指南:印度尼西亚、印度、韩国
数据库·python·金融·数据分析·区块链
她说彩礼65万41 分钟前
C# 中的锁
开发语言·c#
2302_8097983241 分钟前
【JavaWeb】JDBC
java·开发语言·servlet
胖哥真不错1 小时前
Python实现NOA星雀优化算法优化卷积神经网络CNN回归模型项目实战
python·cnn·卷积神经网络·项目实战·cnn回归模型·noa星雀优化算法
繁依Fanyi1 小时前
ImgShrink:摄影暗房里的在线图片压缩工具开发记
开发语言·前端·codebuddy首席试玩官
卓律涤1 小时前
【找工作系列①】【大四毕业】【复习】巩固JavaScript,了解ES6。
开发语言·前端·javascript·笔记·程序人生·职场和发展·es6
xqlily1 小时前
MATLAB安装常见问题解决方案
开发语言·matlab