gpt4 book ai didi

php - 在 Twig 中有条件地扩展模板

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:49:17 26 4
gpt4 key购买 nike

采用以下树结构:

├───base
│ ├───0001
│ │ └───pages
│ │ file.twig
│ │ file_content.twig
│ └───ext
│ └───store
│ │ └───pages
│ │ └───all
│ │ │ file.twig
│ │ └───0001
│ │ file.twig
│ └───newsletter
│ └───pages
│ └───all
│ │ file.twig
│ └───0001
│ file.twig
└───pages
│ file.twig
└───0001
file.twig

如您所见,负载为 file.twig散落一地。

我要渲染文件base/0001/pages/file_content.twig的内容.
但是,我希望以下文件可以更改 block 内的内容:

  • ext/<...>/pages/0001/file.twig
  • ext/<...>/pages/all/file.twig
  • /pages/0001/file.twig
  • /pages/file.twig

但是,这些文件可能存在也可能不存在,可能需要也可能不需要并且必须能够更改任何 block 的内容。

有什么方法可以让它工作吗?

到目前为止,我有以下内容:

{% embed 'base/pages/file_content.twig' %}
{% block page_file %}
{{ parent() }}
{% if data.store_enabled %}
{% include [
'base/ext/store/pages/0001/file.twig',
'base/ext/store/pages/all/file.twig'
] ignore missing
%}
{% endif %}
{% include ['pages/0001/file.twig', 'pages/file.twig'] ignore missing %}
{% endblock %}
{% endembed %}

这“有效”,因为它呈现页面但不允许覆盖任何 block 。

我怎样才能使它工作?


例如,考虑这种文件结构(是的,文件丢失,这是预期的):

    ├───base
│ ├───0001
│ │ └───pages
│ │ file.twig
│ │ file_content.twig
│ └───ext
│ └───store
│ │ └───pages
│ │ └───0001
│ │ file.twig
└───pages
file.twig

文件base/0001/pages/file_content.twig具有以下内容:

{% block page_file %}
{% block title %}<h1>Nice title</h1>{% endblock %}
{% block price %}{% endblock %}
<div class="clearfix"></div>
{% endblock %}

文件base/ext/store/pages/0001/file.twig具有以下内容:

{% block price %}<span class="price">55 &euro;</span>{% endblock %}

和文件pages/file.twig有:

{% block title %}{{ parent() }}<hr>{% endblock %}
{% block price %}<div>{{ parent() }}</div>{% endblock %}

我期望的输出如下:

<h1>Nice title</h1><hr>
<div><span class="price">55 &euro;</span</div>
<div class="clearfix"></div>

但是使用该代码,所有其他文件的更改都将被忽略,输出仅为以下内容:

<h1>Nice title</h1>
<div class="clearfix"></div>

注意:

重要的是要注意我使用的是 Twig 1.33.2,并使用 Twig_Autoloader::register();方法。

我不能使用 Twig 2.x,因为它需要 PHP 7.0+,而我只能使用 PHP 5.3.29。

最佳答案

经过多次尝试,我终于想出了一个办法。

这看起来很丑陋......

假设结构:

├───base
│ ├───0001
│ │ └───pages
│ │ file.twig
│ │ file_content.twig
│ └───ext
│ └───store
│ │ └───pages
│ │ └───0001
│ │ file.twig
└───pages
file.twig

主文件(base/pages/file.twig)有以下代码:

{% if data.store_enabled %}
{% include [
'base/ext/store/pages/0001/file.twig',
'base/ext/store/pages/all/file.twig',

'base/pages/file_content.twig'
] ignore missing
%}
{% else %}
{% include [
'pages/0001/file.twig',
'pages/file.twig',

'base/pages/file_content.twig'
] ignore missing
%}
{% endif %}

这将包括 base/ext/store/pages/ 中的文件(如果存在)。如果那里缺少文件,则会包含文件 base/pages/file_content.twig

base/ext/store/pages/ 中的所有文件顶部必须有以下代码:

{% extends [
'pages/0001/file.twig',
'pages/file.twig',

'base/pages/file_content.twig'
]
%}

并且 pages/ 中的文件必须具有以下内容:

{% extends 'base/pages/file_content.twig' %}

这允许您覆盖 base/pages/file_content.twig 中的any block ,并且文件仅在存在时被包含/扩展。

有保证文件(在这种情况下,base/pages/file_content.twig 必须 始终存在)仍将显示“默认”内容,并且不会抛出一个讨厌的异常。


在这个答案的范围之外,我最初发现了一个非常相似的方法,它使用了条件值。

试穿:https://twigfiddle.com/u06tur

关于php - 在 Twig 中有条件地扩展模板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43975210/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com