gpt4 book ai didi

php - 在 include 中设置 Twig 变量并在之后使用它

转载 作者:可可西里 更新时间:2023-10-31 23:47:48 26 4
gpt4 key购买 nike

假设您有一个包含另一个模板的 Twig 模板 (tplA.twig)

<p>Twig template A</p>

{% set test = "in tpl A" %}
<p>first, variable is: {{ test }}</p>

{% include "tplB.twig" %}
<p>and the variable is: {{ test }}</p>

和包含的模板(tplB.twig)

<div>Content of tpl B</div>
{% set test = "now is tpl B" %}

在包含的模板中设置/更改变量并在主模板中使用它的最佳方法是什么?如何使用全局变量?请注意,我不能使用 block 和扩展,而且我没有使用 Symfony。

非常感谢

编辑

真正的上下文是一个非常基本的多语言结构。对于一个页面,我有一个主模板:

<h1>{{ i18n('mainTitle') }}</h1>
<h2>current language (fr, en): {{ ln }}</h2>

<!-- here a list of photos, but not in a foreach loop -->
<div>
<div>
<img src="/same/for/all/languages-a.jpg" alt="localized A" />
<span>localized A</span>
</div>
<div>
<img src="/same/for/all/languages-b.jpg" alt="localized B" />
<span>localized B</span>
</div>
<!-- etc. -->
</div>

这是一个非常小的网站,所以我没有使用数据库创建复杂的结构,我想在模板中管理所有这些东西。

问题是:如何显示正确的本地化字符串?我想到的是包含一个本地化模板,以分离关注点。像这样的东西:

<!-- before the photos list -->
{% include ln ~ '/photos-list.twig' %}
<!-- then the photos list -->

在这个模板中,我会在正确的语言环境中设置所有变量,这样我就可以在我的照片列表中使用它们。 (如我问题的第一部分所述)

请注意,我对所有其他页面都有此结构。文本内容在 locale 文件夹中是分开的,每个页面都有一个主模板(同样,这是一个非常基本的个人网站)

我最后所做的是在照片列表之前插入一个 hudge if 语句。如果语言环境是 fr,则使用法语文本设置变量,如果是 en,则使用英语文本设置变量。

这就是诀窍,所以我同意 ^^

最佳答案

为什么不移动{{ test }}的第二个电话呢?在 tplB (为了这个场合)?

<div>Content of tpl B</div>
{% set test = "now is tpl B" %}
<p>and the variable is: {{ test }}</p>

关于php - 在 include 中设置 Twig 变量并在之后使用它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26422618/

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