如何在树枝模板文件中定义全局变量?

How can I define global variables inside a twig template file?

是否可以在 twig 文件中设置全局变量,以便我可以从其他文件、宏和块访问该变量。

例如,我想要 variables.twig 文件并在其中设置我的变量,然后我可以将其包含在其他模板中。

我知道可以从框架(例如 Symfony)设置全局变量,但我想要一个仅使用 twig 功能的解决方案。

使用 Symfony 配置

如果您使用的是 Symfony2+,您可以在 config.yml 文件中设置全局变量:

# app/config/config.yml
twig:
    # ...
    globals:
        myStuff: %someParam%

然后在您的应用程序中的任何位置使用 {{ myStuff }}


使用Twig_Environment::addGlobal

如果你在另一个项目中使用 Twig,你可以直接在环境中设置你的全局变量:

$twig = new Twig_Environment($loader);
$twig->addGlobal('myStuff', $someVariable);

然后在您的应用程序中的任何位置使用 {{ myStuff }}


使用 Twig 模板

当您包含一段 Twig 代码时,您只包含来自该代码的渲染视图,而不是代码本身。所以在设计上不可能按照您正在寻找的方式包含一组变量。

Symfony 4 开始,您可以在 config/packages/twig.yaml.

中设置全局变量
# config/packages/twig.yaml
twig:
    # ...
    globals:
        ga_tracking: 'UA-xxxxx-x'

您似乎可以在 top-level 模板中分配全局 READONLY 变量,并在所有基础模板中使用它们。但是你当然不能覆盖它们。 它涵盖了我的情况,也许对其他人有用。

base.html.twig

<!DOCTYPE html>
{# assign global vars here #}
{% set myReadonlyJar = your_custom_ext_twig_function() %} 
<html>
    <body>
        {% block body %}{% endblock %}
    </body>
</html>

my_page.twig

{% extends 'stack/base.html.twig' %}

{% block body %}
    {{ myReadonlyJar.v1 }}

    {{ myReadonlyJar.v2 }}
    {{ include('stack/deep.twig') }}
{% endblock %}

deep.twig

Check top vars very deep inside: <br>
{{ myReadonlyJar.v2 }}

使用 SlimFrameworkTwig-View:3.0

可以使用以下方法Twig::offsetSet

$twig = Twig::create('view/templates');
$twig->offsetSet('globalVar', 'globalVarValue');