Home

Tags

jinja2, построение шаблонов

2010-05-19 jinja

В большинстве веб проектов используется один базовый шаблон, а все страницы этого проекта строятся на основе его с некоторыми изменениями, например отличается поле title, содержимое и др. С помощью jinja2 такую структуру можно реализовать использую блоки ( extends, block ).

Делаем базовый шаблон base.html, в котором будем подменять поля title, head, content, footer

<html>
<head>
    {% block head %}
    <link rel="stylesheet" href="style.css" />
    <title>{% block title %}{% endblock %} - My Webpage</title>
    {% endblock %}
</head>
<body>
    <div id="content">{% block content %}{% endblock %}</div>
    <div id="footer">
        {% block footer %}
        &copy; Copyright 2010 by <a href="http:/example.com/">you</a>.
        {% endblock %}
    </div>
</body></html>

Делаем страницу на основе base.html
{% extends "base.html" %}
{% block title %}Index{% endblock %}
{% block head %}
    {{ super() }}
    <style type="text/css">
        .important { color: #336699; }
    </style>
{% endblock %}
{% block content %}
    <h1>Index</h1>
    <p class="important">
      Welcome on my awesome homepage.
    </p>
{% endblock %}
тут мы подменяем блоки title и content, а блок head подменяем с сохранением содержимого с базовой страницы вызвав метод {{ super() }}


В jinja есть возможность включать содержимое других файлов в указанное место, это делается методом
 {% include 'file.html' %}