Heim  >  Artikel  >  Backend-Entwicklung  >  Ein tiefer Einblick in die Template-Engine von Django und Jinja2 von Flask

Ein tiefer Einblick in die Template-Engine von Django und Jinja2 von Flask

PHPz
PHPzOriginal
2023-09-28 11:39:291409Durchsuche

Ein tiefer Einblick in die Template-Engine von Django und Jinja2 von Flask

Vertiefte Kenntnisse der Template-Engine von Django und Jinja2 von Flask, spezifische Codebeispiele sind erforderlich

Einführung:
Django und Flask sind zwei häufig verwendete und beliebte Web-Frameworks in Python. Beide bieten leistungsstarke Template-Engines für die Darstellung dynamischer Webseiten. Django verwendet eine eigene Template-Engine, während Flask Jinja2 verwendet. In diesem Artikel werfen wir einen detaillierten Blick auf die Template-Engine von Django und Jinja2 von Flask und stellen einige konkrete Codebeispiele bereit, um deren Verwendung und Unterschiede zu veranschaulichen.

1. Django-Vorlagen-Engine

  1. Erstellung und Verwendung von Vorlagen
    In Django können Sie eine Vorlage erstellen, indem Sie eine HTML-Datei erstellen und darin die Vorlagensyntax verwenden. Vorlagendateien werden normalerweise im Verzeichnis „templates“ der Anwendung gespeichert.
    Zum Beispiel können wir eine Vorlage namens „hello.html“ erstellen, wie unten gezeigt:
<!DOCTYPE html>
<html>
<head>
    <title>Hello</title>
</head>
<body>
    <h1>Hello, {{ name }}!</h1>
</body>
</html>

In der Ansichtsfunktion können wir die Daten an die Vorlage übergeben und sie mit render rendern Funktion. Beispielsweise können wir eine Variable mit dem Namen „name“ an die Vorlage übergeben: render函数将数据传递给模板并进行渲染。例如,我们可以传递一个名为“name”的变量给模板:

from django.shortcuts import render

def hello(request):
    name = "John"
    return render(request, 'hello.html', {'name': name})
  1. 模板语法
    Django的模板引擎提供了丰富的语法来处理逻辑和数据展示。下面是一些常用的模板语法示例:
  • 变量:使用双花括号来包含变量名,例如{{ name }}
  • 标签:使用花括号和百分号来包含标签,例如{% for item in items %} {% endfor %}
  • 过滤器:可以在变量后面使用管道符号和过滤器来处理变量的输出,例如{{ name|title }}表示将name变量转换为首字母大写的形式。
  1. 模板继承
    Django的模板引擎还支持模板的继承。可以创建一个基础模板,然后其他模板可以继承基础模板,并可以重写和扩展基础模板的一些块。
    例如,我们可以创建一个名为“base.html”的基础模板,如下所示:
<!DOCTYPE html>
<html>
<head>
    <title>{% block title %}{% endblock %}</title>
</head>
<body>
    <header>
        {% block header %}{% endblock %}
    </header>
    <div class="content">
        {% block content %}{% endblock %}
    </div>
    <footer>
        {% block footer %}{% endblock %}
    </footer>
</body>
</html>

然后,在其他模板中可以使用extends关键字来继承并扩展基础模板,如下所示:

{% extends 'base.html' %}

{% block title %}Hello{% endblock %}

{% block header %}
    <h1>Welcome to my website!</h1>
{% endblock %}

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

二、Flask的Jinja2

  1. 模板的创建和使用
    与Django类似,Flask使用Jinja2作为其模板引擎。同样,可以通过创建一个HTML文件来创建模板。
    在Flask中,模板文件通常存储在应用程序的“templates”目录下。
    例如,我们可以创建一个名为“hello.html”的模板,如下所示:
<!DOCTYPE html>
<html>
<head>
    <title>Hello</title>
</head>
<body>
    <h1>Hello, {{ name }}!</h1>
</body>
</html>

在视图函数中,可以使用render_template函数来渲染模板并传递数据。例如,我们可以传递一个名为“name”的变量给模板:

from flask import Flask, render_template

app = Flask(__name__)

@app.route('/')
def hello():
    name = "John"
    return render_template('hello.html', name=name)
  1. 模板语法
    Jinja2的模板语法与Django的模板语法类似,但有些细微差别。下面是一些常用的模板语法示例:
  • 变量:同样使用双花括号来包含变量名,例如{{ name }}
  • 控制结构:使用花括号和百分号来包含控制结构,例如{% for item in items %} {% endfor %}
  • 过滤器:同样可以在变量后面使用管道符号和过滤器来处理变量的输出,例如{{ name|title }}表示将name变量转换为首字母大写的形式。
  1. 模板继承
    Jinja2也支持模板的继承。同样可以创建一个基础模板,其他模板可以继承并重写和扩展基础模板的一些块。
    例如,我们可以创建一个名为“base.html”的基础模板,如下所示:
<!DOCTYPE html>
<html>
<head>
    <title>{% block title %}{% endblock %}</title>
</head>
<body>
    <header>
        {% block header %}{% endblock %}
    </header>
    <div class="content">
        {% block content %}{% endblock %}
    </div>
    <footer>
        {% block footer %}{% endblock %}
    </footer>
</body>
</html>

然后,在其他模板中使用extends

{% extends 'base.html' %}

{% block title %}Hello{% endblock %}

{% block header %}
    <h1>Welcome to my website!</h1>
{% endblock %}

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

    Vorlagensyntax

    Djangos Vorlagen-Engine bietet eine umfangreiche Syntax für die Handhabung von Logik und Datenpräsentation. Hier sind einige häufig verwendete Vorlagensyntaxbeispiele:

    Variablen: Verwenden Sie doppelte geschweifte Klammern, um Variablennamen einzuschließen, z. B. {{ name }}.

    🎜 Tags: Verwenden Sie geschweifte Klammern und Prozentzeichen, um Tags einzuschließen, z. B. {% für item in items %} {% endfor %}. 🎜🎜Filter: Sie können Pipe-Symbole und Filter nach Variablen verwenden, um die Ausgabe von Variablen zu verarbeiten. Beispielsweise bedeutet {{ name|title }}, dass die Namensvariable in eine Großschreibung umgewandelt wird. 🎜
    🎜Template-Vererbung🎜Djangos Template-Engine unterstützt auch die Template-Vererbung. Eine Basisvorlage kann erstellt werden, und dann können andere Vorlagen die Basisvorlage erben und einige Blöcke der Basisvorlage überschreiben und erweitern. 🎜Zum Beispiel können wir eine Basisvorlage mit dem Namen „base.html“ wie folgt erstellen: 🎜🎜rrreee🎜Dann kann das Schlüsselwort extends in anderen Vorlagen verwendet werden, um die Basisvorlage zu erben und zu erweitern unten gezeigt: 🎜rrreee🎜2. Erstellung und Verwendung der Jinja2-Vorlage von Flask. Ähnlich wie Django verwendet Flask Jinja2 als Vorlagen-Engine. Ebenso können Vorlagen durch die Erstellung einer HTML-Datei erstellt werden. 🎜In Flask werden Vorlagendateien normalerweise im Verzeichnis „templates“ der Anwendung gespeichert. 🎜Zum Beispiel können wir eine Vorlage mit dem Namen „hello.html“ erstellen, wie unten gezeigt: 🎜🎜rrreee🎜In der Ansichtsfunktion können Sie die Funktion render_template verwenden, um die Vorlage zu rendern und die Daten zu übergeben. Beispielsweise können wir eine Variable mit dem Namen „name“ an die Vorlage übergeben: 🎜rrreee
      🎜Vorlagensyntax🎜Die Vorlagensyntax von Jinja2 ähnelt der Vorlagensyntax von Django, weist jedoch einige subtile Unterschiede auf. Hier sind einige Beispiele für gängige Vorlagensyntax: 🎜🎜
    🎜Variablen: Verwenden Sie auch doppelte geschweifte Klammern, um Variablennamen einzuschließen, z. B. {{ name }}. 🎜🎜Kontrollstrukturen: Verwenden Sie geschweifte Klammern und Prozentzeichen, um Kontrollstrukturen einzuschließen, z. B. {% für item in items %} {% endfor %}. 🎜🎜Filter: Sie können auch Pipe-Symbole und Filter nach Variablen verwenden, um die Ausgabe von Variablen zu verarbeiten. Beispielsweise bedeutet {{ name|title }}, dass die Namensvariable in einen Großbuchstaben umgewandelt wird. 🎜
    🎜Vorlagenvererbung🎜Jinja2 unterstützt auch die Vorlagenvererbung. Es ist auch möglich, eine Basisvorlage zu erstellen, und andere Vorlagen können einige Blöcke der Basisvorlage erben, überschreiben und erweitern. 🎜Zum Beispiel können wir eine Basisvorlage mit dem Namen „base.html“ wie folgt erstellen: 🎜🎜rrreee🎜 Dann verwenden Sie das Schlüsselwort extends in anderen Vorlagen, um die Basisvorlage zu erben und zu erweitern, wie unten gezeigt : 🎜rrreee🎜 Fazit: 🎜 Sowohl die Template-Engine von Django als auch Jinja2 von Flask bieten leistungsstarke Funktionen zum Erstellen dynamischer Webseiten-Renderings. Es gibt einige geringfügige Unterschiede in der Syntax und Verwendung zwischen den beiden, aber insgesamt sind sie sehr ähnlich. In der tatsächlichen Entwicklung können Sie je nach persönlichen Vorlieben oder Projektanforderungen eine davon verwenden. 🎜🎜Das Obige ist ein tiefgreifendes Verständnis der Template-Engine von Django und von Flasks Jinja2. Durch spezifische Codebeispiele erhalten wir ein klareres Verständnis ihrer Verwendung und Unterschiede. Ich hoffe, dass dieser Artikel Ihnen dabei hilft, diese beiden Vorlagen-Engines zu verstehen und zu verwenden. 🎜

Das obige ist der detaillierte Inhalt vonEin tiefer Einblick in die Template-Engine von Django und Jinja2 von Flask. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn