我有树枝变量 html。为了在树枝模板中显示它,我做了 {{html}}。该变量看起来像 {{region_top}}{{region_center}}。 Region_* 也是变量。当 twig 解析我的 html 变量时,他没有解析内部变量(区域)。我该怎么办?
Twig 将您的字符串视为文字字符串,这意味着您将看到转义的变量内容。如果您希望它也能够显示 {{region_top}},我建议如下:
{{html|replace({'{{region_top}}': region_top, '{{region_center}}': region_center})}}
如果您的 html 变量的内容也是动态的(意味着它可以包含的不仅仅是这两个变量),我会编写一个 twig 插件,它可以完成您想要的操作。编写插件非常容易。
EDIT:这是我刚刚写完的扩展。
EDIT 2:扩展现在使用环境来呈现字符串,因此它会评估字符串,而不仅仅是替换变量。这意味着你的变量可以包含模板可以包含的任何内容,并且它将由 Twig 本身渲染和转义。我真棒。
<?php
/**
* A twig extension that will add an "evaluate" filter, for dynamic evaluation.
*/
class EvaluateExtension extends \Twig_Extension {
/**
* Attaches the innervars filter to the Twig Environment.
*
* @return array
*/
public function getFilters( ) {
return array(
'evaluate' => new \Twig_Filter_Method( $this, 'evaluate', array(
'needs_environment' => true,
'needs_context' => true,
'is_safe' => array(
'evaluate' => true
)
))
);
}
/**
* This function will evaluate $string through the $environment, and return its results.
*
* @param array $context
* @param string $string
*/
public function evaluate( \Twig_Environment $environment, $context, $string ) {
$loader = $environment->getLoader( );
$parsed = $this->parseString( $environment, $context, $string );
$environment->setLoader( $loader );
return $parsed;
}
/**
* Sets the parser for the environment to Twig_Loader_String, and parsed the string $string.
*
* @param \Twig_Environment $environment
* @param array $context
* @param string $string
* @return string
*/
protected function parseString( \Twig_Environment $environment, $context, $string ) {
$environment->setLoader( new \Twig_Loader_String( ) );
return $environment->render( $string, $context );
}
/**
* Returns the name of this extension.
*
* @return string
*/
public function getName( ) {
return 'evaluate';
}
}
用法示例:
$twig_environment->addExtension( new EvaluateExtension( ) );
在模板中:
{% set var = 'inner variable' %}
{{'this is a string with an {{var}}'|evaluate}}