jinja2 如何在一个模板引入另一个模板中的block

发布于 2022-09-06 22:50:09 字数 2937 浏览 24 评论 0

我想用纯jinja2(不用框架)做一个输出以文章形式为主体的网页模板,有一个基础的骨架base.html,有大量的章节,这些章节会自由组合放入骨架中,如果这些章节用macro放将会很麻烦,因为章节中有一些重复使用的图片表格元素也需要放在macro中,但是这些章节用block也很不好办,因为block不能用import引入骨架并且还不能传参数。

我在网上看到好像可以用template的.blocks属性调用block,所以有了以下尝试:

#config.json
{"templates":[
        {"title":"chapter1",
        "children":[
                {"title":"chapter1_1","template":"template1.html","block":"block1"},
                {"title":"chapter1_2","template":"template2.html","block":"block1","parameter":{"note":"hello world"}},
        ]},
        {"title":"chapter2","template":"template1.html","block":"block2","parameter":{"note":"blabla"}}
]}


#base.html
{% from "component.html" import common_table as common_table with context %}
{% from "component.html" import common_img as common_img with context %}
{%- for chapter in chapter_list %}
        {%- set ch_loop = loop %}
        <h2>{{ ch_loop.index }}&nbsp;{{ chapter.title }}</h2>
        {%- if chapter.children %}
                {%- for section in chapter.children %}
                        <h3>{{ ch_loop.index }}.{{ loop.index }}&nbsp;{{ section.title }}</h3>
                        {% import section.template as template with context %}
                        {% set parameter=section.parameter %}
                        {{ template.blocks[section.block] }}
                {%- endfor %}
        {%- else %}
                {% import chapter.template as template with context %}
                {% set parameter=chapter.parameter %}
                {{ template.blocks[chapter.block] }}
        {%- endif %}
{%- endfor %}

#template1.html 
{% block block1 %}
        I am block 1
        {{ common_table(id="table1",head="nohead")  }}
        {{ common_img(src="css/icon/icon1.png")  }}
{% endblock %}

{% block block2 %}
        I am block 2
        {{ common_img(src="css/icon/icon2.png")  }}
        {% if parameter.note=="blabla" %}
                {{ "blabla~blabla~" }}
        {% endif %}
{% endblock %}

#component.html
{% macro common_table(id, name,note, head="onehead") %}
        {% if name %}
                <b class="tablename">{{ name }}</b>
        {% endif %}
        <table id="{{ id }}" class=" {{ head }}"></table>
        {% if note %}
                 <p class="tablenote">{{ note }}</p>
        {% endif %}
{% endmacro %}

{% macro common_img(src, alt, name) %}
        <img  src="{{ src }}" alt="{{ alt }}">
        {% if name %}
                <b class="imgname">{{ name }}</b>
        {% endif %}
{% endmacro %}

但是jinja2报了以下错误:

jinja2.exceptions.UndefinedError: 'jinja2.environment.TemplateModule object' has no attribute 'blocks'

我查看了jinja2的源代码,发现在python脚本中好像可以用.blocks属性调用Template对象的block,但是在模板中不行,因为模板中import进来的是TemplateModule class,这个类没有blocks属性,好像也不输出block。那么请问我该如何在骨架中引入block呢,还是需要修改我的构建模板的方法?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

花想c 2022-09-13 22:50:09

已解决,解决办法是章节使用macro,重复使用的图表元素使用jquery添加

摇划花蜜的午后 2022-09-13 22:50:09

为什么不用include

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文