Я использовал from_string
для рендеринга из строки, а не из файла.
my_jinja.from_string(my_string).render(**some_params)
Он успешно отображает переменные, но как я могу загрузить / импортировать файл макета с помощью {% block %}
при использовании from_string
в Jinja2
?
Я хочу реализовать приведенную ниже структуру в from_string
, как мне это сделать?
base.html
file:
<!DOCTYPE html>
<html lang="en">
<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 %}
© Copyright 2008 by <a href="http://domain.invalid/">you</a>.
{% endblock %}
</div>
</body>
</html>
В этом примере теги {% block %}
определяют четыре блока, которые могут заполнять дочерние шаблоны.
Дочерний шаблон может выглядеть следующим образом:
{% 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 to my awesome homepage.
</p>
{% endblock %}
Как мы можно сделать blocks
при использовании strings
, а не files
для визуализации шаблонов?