如何在树枝模板文件中定义全局变量?
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 }}
使用 SlimFramework
和 Twig-View:3.0
可以使用以下方法Twig::offsetSet
$twig = Twig::create('view/templates');
$twig->offsetSet('globalVar', 'globalVarValue');
是否可以在 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 }}
使用 SlimFramework
和 Twig-View:3.0
可以使用以下方法Twig::offsetSet
$twig = Twig::create('view/templates');
$twig->offsetSet('globalVar', 'globalVarValue');